@woosh/meep-engine 2.156.0 → 2.157.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 (654) hide show
  1. package/README.md +1 -3
  2. package/editor/view/ecs/components/common/AutoCanvasView.js +100 -53
  3. package/editor/view/ecs/components/common/TextController.js +59 -0
  4. package/editor/view/node-graph/NodeGraphCamera.js +90 -0
  5. package/editor/view/node-graph/NodeGraphEditorView.js +121 -22
  6. package/editor/view/node-graph/NodeGraphSelection.js +89 -0
  7. package/editor/view/node-graph/NodeGraphView.js +669 -453
  8. package/editor/view/node-graph/NodeView.js +211 -135
  9. package/editor/view/node-graph/actions/ConnectionCreateAction.js +53 -0
  10. package/editor/view/node-graph/actions/ConnectionDeleteAction.js +36 -0
  11. package/editor/view/node-graph/actions/NodeDeleteAction.js +88 -0
  12. package/editor/view/node-graph/actions/NodeParameterSetAction.js +52 -0
  13. package/editor/view/node-graph/actions/NodesMoveAction.js +41 -0
  14. package/editor/view/node-graph/actions/SelectionSetAction.js +60 -0
  15. package/editor/view/node-graph/connection_wire_geometry.js +107 -0
  16. package/package.json +1 -1
  17. package/samples/generation/SampleGenerator0.js +8 -1
  18. package/src/core/binary/reinterpret_float32_as_uint32.d.ts +7 -0
  19. package/src/core/binary/reinterpret_float32_as_uint32.d.ts.map +1 -0
  20. package/src/core/binary/reinterpret_float32_as_uint32.js +13 -0
  21. package/src/core/binary/reinterpret_uint32_as_float32.d.ts +7 -0
  22. package/src/core/binary/reinterpret_uint32_as_float32.d.ts.map +1 -0
  23. package/src/core/binary/reinterpret_uint32_as_float32.js +14 -0
  24. package/src/core/bvh2/bvh3/ebvh_build_for_geometry_incremental.d.ts.map +1 -1
  25. package/src/core/bvh2/bvh3/ebvh_build_for_geometry_incremental.js +1 -3
  26. package/src/core/bvh2/bvh3/query/bvh_query_user_data_overlaps_sphere.d.ts +12 -0
  27. package/src/core/bvh2/bvh3/query/bvh_query_user_data_overlaps_sphere.d.ts.map +1 -0
  28. package/src/core/bvh2/bvh3/query/bvh_query_user_data_overlaps_sphere.js +92 -0
  29. package/src/core/bvh8/BVH8.d.ts +127 -0
  30. package/src/core/bvh8/BVH8.d.ts.map +1 -0
  31. package/src/core/bvh8/BVH8.js +436 -0
  32. package/src/core/bvh8/NOTES.md +63 -0
  33. package/src/core/bvh8/build/BVH8Converter.d.ts +59 -0
  34. package/src/core/bvh8/build/BVH8Converter.d.ts.map +1 -0
  35. package/src/core/bvh8/build/BVH8Converter.js +588 -0
  36. package/src/core/bvh8/build/NodeProxy.d.ts +66 -0
  37. package/src/core/bvh8/build/NodeProxy.d.ts.map +1 -0
  38. package/src/core/bvh8/build/NodeProxy.js +308 -0
  39. package/src/core/bvh8/build/TriangleCluster.d.ts +29 -0
  40. package/src/core/bvh8/build/TriangleCluster.d.ts.map +1 -0
  41. package/src/core/bvh8/build/TriangleCluster.js +123 -0
  42. package/src/core/bvh8/build/aabb3_compute_merge_cost.d.ts +8 -0
  43. package/src/core/bvh8/build/aabb3_compute_merge_cost.d.ts.map +1 -0
  44. package/src/core/bvh8/build/aabb3_compute_merge_cost.js +29 -0
  45. package/src/core/bvh8/build/aabb3_from_triangle_by_index.d.ts +10 -0
  46. package/src/core/bvh8/build/aabb3_from_triangle_by_index.d.ts.map +1 -0
  47. package/src/core/bvh8/build/aabb3_from_triangle_by_index.js +18 -0
  48. package/src/core/bvh8/build/bvh8_build_for_geometry.d.ts +10 -0
  49. package/src/core/bvh8/build/bvh8_build_for_geometry.d.ts.map +1 -0
  50. package/src/core/bvh8/build/bvh8_build_for_geometry.js +303 -0
  51. package/src/core/bvh8/build/bvh8_from_proxy.d.ts +9 -0
  52. package/src/core/bvh8/build/bvh8_from_proxy.d.ts.map +1 -0
  53. package/src/core/bvh8/build/bvh8_from_proxy.js +256 -0
  54. package/src/core/bvh8/build/byte.d.ts +7 -0
  55. package/src/core/bvh8/build/byte.d.ts.map +1 -0
  56. package/src/core/bvh8/build/byte.js +10 -0
  57. package/src/core/bvh8/build/encode_bounds_e.d.ts +9 -0
  58. package/src/core/bvh8/build/encode_bounds_e.d.ts.map +1 -0
  59. package/src/core/bvh8/build/encode_bounds_e.js +12 -0
  60. package/src/core/bvh8/bvh8_convert_to_dot.d.ts +11 -0
  61. package/src/core/bvh8/bvh8_convert_to_dot.d.ts.map +1 -0
  62. package/src/core/bvh8/bvh8_convert_to_dot.js +133 -0
  63. package/src/core/bvh8/bvh8_count_primitives.d.ts +22 -0
  64. package/src/core/bvh8/bvh8_count_primitives.d.ts.map +1 -0
  65. package/src/core/bvh8/bvh8_count_primitives.js +98 -0
  66. package/src/core/bvh8/bvh8_geometry_validate.d.ts +16 -0
  67. package/src/core/bvh8/bvh8_geometry_validate.d.ts.map +1 -0
  68. package/src/core/bvh8/bvh8_geometry_validate.js +149 -0
  69. package/src/core/bvh8/bvh8_geometry_validate_indirect.d.ts +16 -0
  70. package/src/core/bvh8/bvh8_geometry_validate_indirect.d.ts.map +1 -0
  71. package/src/core/bvh8/bvh8_geometry_validate_indirect.js +177 -0
  72. package/src/core/bvh8/bvh8_get_node_bounds.d.ts +9 -0
  73. package/src/core/bvh8/bvh8_get_node_bounds.d.ts.map +1 -0
  74. package/src/core/bvh8/bvh8_get_node_bounds.js +35 -0
  75. package/src/core/bvh8/bvh8_get_node_child_bounds.d.ts +10 -0
  76. package/src/core/bvh8/bvh8_get_node_child_bounds.d.ts.map +1 -0
  77. package/src/core/bvh8/bvh8_get_node_child_bounds.js +53 -0
  78. package/src/core/bvh8/bvh8_node_child_surface_area.d.ts +9 -0
  79. package/src/core/bvh8/bvh8_node_child_surface_area.d.ts.map +1 -0
  80. package/src/core/bvh8/bvh8_node_child_surface_area.js +18 -0
  81. package/src/core/bvh8/bvh8_node_count_triangles.d.ts +8 -0
  82. package/src/core/bvh8/bvh8_node_count_triangles.d.ts.map +1 -0
  83. package/src/core/bvh8/bvh8_node_count_triangles.js +28 -0
  84. package/src/core/bvh8/bvh8_quality.d.ts +8 -0
  85. package/src/core/bvh8/bvh8_quality.d.ts.map +1 -0
  86. package/src/core/bvh8/bvh8_quality.js +73 -0
  87. package/src/core/bvh8/bvh8_validate_structure.d.ts +15 -0
  88. package/src/core/bvh8/bvh8_validate_structure.d.ts.map +1 -0
  89. package/src/core/bvh8/bvh8_validate_structure.js +87 -0
  90. package/src/core/collection/Uint32MinHeap.d.ts +56 -0
  91. package/src/core/collection/Uint32MinHeap.d.ts.map +1 -0
  92. package/src/core/collection/Uint32MinHeap.js +109 -0
  93. package/src/core/collection/list/FilteredListProjection.js +1 -1
  94. package/src/{engine/physics/island → core/collection/union-find}/union_find.d.ts +8 -5
  95. package/src/core/collection/union-find/union_find.d.ts.map +1 -0
  96. package/src/{engine/physics/island → core/collection/union-find}/union_find.js +8 -5
  97. package/src/core/dom/isImageBitmap.d.ts +7 -0
  98. package/src/core/dom/isImageBitmap.d.ts.map +1 -0
  99. package/src/core/dom/isImageBitmap.js +12 -0
  100. package/src/core/function/frameThrottle.d.ts +8 -0
  101. package/src/core/function/frameThrottle.d.ts.map +1 -0
  102. package/src/core/function/frameThrottle.js +23 -0
  103. package/src/{engine/physics/narrowphase/clip_against_axis_uv.d.ts → core/geom/2d/polygon/polygon2_clip_axis_halfplane.d.ts} +3 -3
  104. package/src/core/geom/2d/polygon/polygon2_clip_axis_halfplane.d.ts.map +1 -0
  105. package/src/{engine/physics/narrowphase/clip_against_axis_uv.js → core/geom/2d/polygon/polygon2_clip_axis_halfplane.js} +51 -51
  106. package/src/{engine/physics/narrowphase/decomposition/aabb_world_to_local.d.ts → core/geom/3d/aabb/aabb3_transform_oriented_inverse.d.ts} +9 -7
  107. package/src/core/geom/3d/aabb/aabb3_transform_oriented_inverse.d.ts.map +1 -0
  108. package/src/{engine/physics/narrowphase/decomposition/aabb_world_to_local.js → core/geom/3d/aabb/aabb3_transform_oriented_inverse.js} +9 -7
  109. package/src/core/geom/3d/aabb/compute_triangle_group_aabb3.d.ts +12 -0
  110. package/src/core/geom/3d/aabb/compute_triangle_group_aabb3.d.ts.map +1 -0
  111. package/src/core/geom/3d/aabb/compute_triangle_group_aabb3.js +46 -0
  112. package/src/core/geom/3d/box/box3_projected_half_extent.d.ts +28 -0
  113. package/src/core/geom/3d/box/box3_projected_half_extent.d.ts.map +1 -0
  114. package/src/core/geom/3d/box/box3_projected_half_extent.js +35 -0
  115. package/src/core/geom/3d/frustum/read_cluster_frustum_corners.js +1 -1
  116. package/src/core/geom/3d/frustum/read_frustum_corner.d.ts +9 -0
  117. package/src/core/geom/3d/frustum/read_frustum_corner.d.ts.map +1 -0
  118. package/src/core/geom/3d/frustum/read_frustum_corner.js +14 -0
  119. package/src/core/geom/3d/gjk/gjk.d.ts.map +1 -0
  120. package/src/{engine/physics → core/geom/3d}/gjk/gjk.js +430 -372
  121. package/src/{engine/physics → core/geom/3d}/gjk/gjk_epa_penetration.d.ts +8 -5
  122. package/src/core/geom/3d/gjk/gjk_epa_penetration.d.ts.map +1 -0
  123. package/src/{engine/physics → core/geom/3d}/gjk/gjk_epa_penetration.js +520 -544
  124. package/src/{engine/physics → core/geom/3d}/gjk/minkowski_support.d.ts +5 -4
  125. package/src/core/geom/3d/gjk/minkowski_support.d.ts.map +1 -0
  126. package/src/{engine/physics → core/geom/3d}/gjk/minkowski_support.js +71 -70
  127. package/src/{engine/physics → core/geom/3d}/gjk/mpr.d.ts +3 -3
  128. package/src/core/geom/3d/gjk/mpr.d.ts.map +1 -0
  129. package/src/{engine/physics → core/geom/3d}/gjk/mpr.js +368 -362
  130. package/src/{engine/physics/integration/quat_integrate.d.ts → core/geom/3d/quaternion/quat3_integrate.d.ts} +2 -2
  131. package/src/core/geom/3d/quaternion/quat3_integrate.d.ts.map +1 -0
  132. package/src/{engine/physics/integration/quat_integrate.js → core/geom/3d/quaternion/quat3_integrate.js} +1 -1
  133. package/src/{engine/physics/narrowphase/PosedShape.d.ts → core/geom/3d/shape/PosedShape3D.d.ts} +9 -8
  134. package/src/{engine/physics/narrowphase/PosedShape.d.ts.map → core/geom/3d/shape/PosedShape3D.d.ts.map} +1 -1
  135. package/src/{engine/physics/narrowphase/PosedShape.js → core/geom/3d/shape/PosedShape3D.js} +10 -9
  136. package/src/core/geom/3d/shape/TransformedShape3D.d.ts.map +1 -1
  137. package/src/core/geom/3d/shape/TransformedShape3D.js +15 -11
  138. package/src/core/geom/vec3/v3_quat3_apply_inverse.d.ts +1 -1
  139. package/src/core/geom/vec3/v3_quat3_apply_inverse.js +1 -1
  140. package/src/core/math/complex/complex_add.d.ts +1 -1
  141. package/src/core/math/complex/complex_add.d.ts.map +1 -1
  142. package/src/core/math/complex/complex_add.js +12 -3
  143. package/src/core/math/complex/complex_div.d.ts +1 -1
  144. package/src/core/math/complex/complex_div.d.ts.map +1 -1
  145. package/src/core/math/complex/complex_div.js +11 -4
  146. package/src/core/math/complex/complex_mul.d.ts +1 -1
  147. package/src/core/math/complex/complex_mul.d.ts.map +1 -1
  148. package/src/core/math/complex/complex_mul.js +10 -3
  149. package/src/core/math/complex/complex_sub.d.ts +1 -1
  150. package/src/core/math/complex/complex_sub.d.ts.map +1 -1
  151. package/src/core/math/complex/complex_sub.js +12 -3
  152. package/src/{engine/physics/fluid/solver/optimal_sor_omega.d.ts → core/math/linalg/sor_optimal_omega.d.ts} +4 -3
  153. package/src/core/math/linalg/sor_optimal_omega.d.ts.map +1 -0
  154. package/src/{engine/physics/fluid/solver/optimal_sor_omega.js → core/math/linalg/sor_optimal_omega.js} +4 -3
  155. package/src/core/math/lookup/ParameterLookupTable.d.ts +123 -0
  156. package/src/core/math/lookup/ParameterLookupTable.d.ts.map +1 -0
  157. package/src/core/math/lookup/ParameterLookupTable.js +495 -0
  158. package/src/core/math/lookup/ParameterLookupTableFlags.d.ts +5 -0
  159. package/src/core/math/lookup/ParameterLookupTableFlags.d.ts.map +1 -0
  160. package/src/core/math/lookup/ParameterLookupTableFlags.js +6 -0
  161. package/src/core/math/physics/kinematics/computeInterceptPoint.d.ts.map +1 -0
  162. package/src/{engine/physics → core/math/physics/kinematics}/computeInterceptPoint.js +79 -79
  163. package/src/core/math/physics/mie/ri_air.d.ts.map +1 -1
  164. package/src/core/math/physics/mie/ri_air.js +1 -3
  165. package/src/core/math/physics/mie/ri_ammonium_sulfate.d.ts.map +1 -1
  166. package/src/core/math/physics/mie/ri_ammonium_sulfate.js +1 -3
  167. package/src/core/math/physics/mie/ri_brine.d.ts.map +1 -1
  168. package/src/core/math/physics/mie/ri_brine.js +1 -3
  169. package/src/core/math/physics/mie/ri_dust.d.ts.map +1 -1
  170. package/src/core/math/physics/mie/ri_dust.js +1 -3
  171. package/src/core/math/physics/mie/ri_pollen.d.ts.map +1 -1
  172. package/src/core/math/physics/mie/ri_pollen.js +1 -3
  173. package/src/core/math/physics/mie/ri_smoke.d.ts.map +1 -1
  174. package/src/core/math/physics/mie/ri_smoke.js +1 -3
  175. package/src/core/math/physics/mie/ri_soot.d.ts.map +1 -1
  176. package/src/core/math/physics/mie/ri_soot.js +1 -3
  177. package/src/core/math/physics/mie/ri_water.d.ts.map +1 -1
  178. package/src/core/math/physics/mie/ri_water.js +1 -3
  179. package/src/core/math/random/random_pick_weighted_index.d.ts +10 -0
  180. package/src/core/math/random/random_pick_weighted_index.d.ts.map +1 -0
  181. package/src/core/math/random/random_pick_weighted_index.js +26 -0
  182. package/src/core/model/node-graph/NodeGraph.d.ts +9 -0
  183. package/src/core/model/node-graph/NodeGraph.d.ts.map +1 -1
  184. package/src/core/model/node-graph/NodeGraph.js +38 -0
  185. package/src/core/model/node-graph/visual/NodeGraphVisualData.d.ts +23 -0
  186. package/src/core/model/node-graph/visual/NodeGraphVisualData.d.ts.map +1 -1
  187. package/src/core/model/node-graph/visual/NodeGraphVisualData.js +54 -0
  188. package/src/core/path/convertPathToURL.d.ts +9 -0
  189. package/src/core/path/convertPathToURL.d.ts.map +1 -0
  190. package/src/core/path/convertPathToURL.js +107 -0
  191. package/src/core/process/worker/WorkerBuilder.js +1 -1
  192. package/src/core/process/worker/extractTransferables.js +1 -1
  193. package/src/engine/animation/curve/draw/build_tangent_editor.d.ts.map +1 -1
  194. package/src/engine/animation/curve/draw/build_tangent_editor.js +8 -1
  195. package/src/engine/animation/curve/editor/createKeyframeDraggableAspect.d.ts.map +1 -1
  196. package/src/engine/animation/curve/editor/createKeyframeDraggableAspect.js +11 -5
  197. package/src/engine/asset/Asset.d.ts.map +1 -1
  198. package/src/engine/asset/Asset.js +16 -6
  199. package/src/engine/asset/AssetManager.d.ts +61 -52
  200. package/src/engine/asset/AssetManager.d.ts.map +1 -1
  201. package/src/engine/asset/AssetManager.js +1411 -1045
  202. package/src/engine/asset/AssetRequest.d.ts +1 -1
  203. package/src/engine/asset/AssetRequest.d.ts.map +1 -1
  204. package/src/engine/asset/AssetRequest.js +1 -1
  205. package/src/engine/asset/AssetRequestScope.d.ts.map +1 -1
  206. package/src/engine/asset/AssetRequestScope.js +7 -0
  207. package/src/engine/asset/PendingAsset.d.ts +32 -1
  208. package/src/engine/asset/PendingAsset.d.ts.map +1 -1
  209. package/src/engine/asset/PendingAsset.js +108 -61
  210. package/src/engine/asset/loaders/ArrayBufferLoader.js +2 -2
  211. package/src/engine/asset/loaders/AssetLoader.d.ts.map +1 -1
  212. package/src/engine/asset/loaders/AssetLoader.js +19 -2
  213. package/src/engine/asset/loaders/GLTFAssetLoader.d.ts.map +1 -1
  214. package/src/engine/asset/loaders/GLTFAssetLoader.js +123 -114
  215. package/src/engine/asset/loaders/JavascriptAssetLoader.d.ts +1 -1
  216. package/src/engine/asset/loaders/JavascriptAssetLoader.d.ts.map +1 -1
  217. package/src/engine/asset/loaders/JavascriptAssetLoader.js +31 -47
  218. package/src/engine/asset/loaders/JsonAssetLoader.js +1 -1
  219. package/src/engine/asset/loaders/SVGAssetLoader.js +2 -2
  220. package/src/engine/asset/loaders/SoundAssetLoader.js +1 -1
  221. package/src/engine/asset/loaders/TextAssetLoader.js +2 -2
  222. package/src/{core → engine/asset/loaders}/font/FontAsset.d.ts +1 -1
  223. package/src/engine/asset/loaders/font/FontAsset.d.ts.map +1 -0
  224. package/src/{core → engine/asset/loaders}/font/FontAsset.js +21 -21
  225. package/src/{core → engine/asset/loaders}/font/FontAssetLoader.d.ts +1 -1
  226. package/src/engine/asset/loaders/font/FontAssetLoader.d.ts.map +1 -0
  227. package/src/{core → engine/asset/loaders}/font/FontAssetLoader.js +20 -20
  228. package/src/engine/asset/loaders/image/ImageRGBADataLoader.d.ts +1 -1
  229. package/src/engine/asset/loaders/image/ImageRGBADataLoader.d.ts.map +1 -1
  230. package/src/engine/asset/loaders/image/ImageRGBADataLoader.js +11 -20
  231. package/src/engine/asset/loaders/texture/TextureAssetLoader.d.ts.map +1 -1
  232. package/src/engine/asset/loaders/texture/TextureAssetLoader.js +8 -2
  233. package/src/engine/asset/preloader/AssetPreloader.js +1 -1
  234. package/src/engine/ecs/sockets/serialization/AttachmentSocketsAssetLoader.d.ts +1 -1
  235. package/src/engine/ecs/sockets/serialization/AttachmentSocketsAssetLoader.d.ts.map +1 -1
  236. package/src/engine/ecs/sockets/serialization/AttachmentSocketsAssetLoader.js +19 -22
  237. package/src/engine/graphics/FrameThrottle.d.ts +1 -7
  238. package/src/engine/graphics/FrameThrottle.d.ts.map +1 -1
  239. package/src/engine/graphics/FrameThrottle.js +2 -24
  240. package/src/{core/geom/3d/shape/util → engine/graphics/debug}/shape_to_visual_entity.d.ts +1 -1
  241. package/src/engine/graphics/debug/shape_to_visual_entity.d.ts.map +1 -0
  242. package/src/{core/geom/3d/shape/util → engine/graphics/debug}/shape_to_visual_entity.js +159 -159
  243. package/src/{core/geom/3d/tetrahedra → engine/graphics/debug}/visualize_tetrahedral_mesh.d.ts +1 -1
  244. package/src/engine/graphics/debug/visualize_tetrahedral_mesh.d.ts.map +1 -0
  245. package/src/{core/geom/3d/tetrahedra → engine/graphics/debug}/visualize_tetrahedral_mesh.js +46 -46
  246. package/src/engine/graphics/ecs/animation/animator/graph/definition/serialization/AnimationGraphDefinitionAssetLoader.d.ts +1 -1
  247. package/src/engine/graphics/ecs/animation/animator/graph/definition/serialization/AnimationGraphDefinitionAssetLoader.d.ts.map +1 -1
  248. package/src/engine/graphics/ecs/animation/animator/graph/definition/serialization/AnimationGraphDefinitionAssetLoader.js +22 -32
  249. package/src/engine/graphics/particles/particular/engine/emitter/serde/ParameterLookupTableSerializationAdapter.d.ts.map +1 -1
  250. package/src/engine/graphics/particles/particular/engine/emitter/serde/ParameterLookupTableSerializationAdapter.js +2 -76
  251. package/src/engine/graphics/particles/particular/engine/parameter/ParameterLookupTable.d.ts.map +1 -1
  252. package/src/engine/graphics/particles/particular/engine/parameter/ParameterLookupTable.js +2 -427
  253. package/src/engine/graphics/particles/particular/engine/parameter/ParameterLookupTableFlags.d.ts +1 -4
  254. package/src/engine/graphics/particles/particular/engine/parameter/ParameterLookupTableFlags.d.ts.map +1 -1
  255. package/src/engine/graphics/particles/particular/engine/parameter/ParameterLookupTableFlags.js +2 -6
  256. package/src/engine/graphics/particles/particular/engine/utils/volume/prototypeParticleVolume.js +1 -1
  257. package/src/engine/graphics/render/forward_plus/read_frustum_corner.d.ts +1 -8
  258. package/src/engine/graphics/render/forward_plus/read_frustum_corner.d.ts.map +1 -1
  259. package/src/engine/graphics/render/forward_plus/read_frustum_corner.js +2 -14
  260. package/src/engine/graphics/sh3/path_tracer/geometry/compute_triangle_group_aabb3.d.ts +1 -11
  261. package/src/engine/graphics/sh3/path_tracer/geometry/compute_triangle_group_aabb3.d.ts.map +1 -1
  262. package/src/engine/graphics/sh3/path_tracer/geometry/compute_triangle_group_aabb3.js +2 -46
  263. package/src/engine/graphics/sh3/prototypeSH3Probe.js +1 -1
  264. package/src/engine/graphics/texture/3d/scs3d_sample_linear3.d.ts +27 -0
  265. package/src/engine/graphics/texture/3d/scs3d_sample_linear3.d.ts.map +1 -0
  266. package/src/engine/graphics/texture/3d/scs3d_sample_linear3.js +81 -0
  267. package/src/engine/graphics/texture/isImageBitmap.d.ts +1 -6
  268. package/src/engine/graphics/texture/isImageBitmap.d.ts.map +1 -1
  269. package/src/engine/graphics/texture/isImageBitmap.js +2 -12
  270. package/src/{core/process/action → engine/intelligence/behavior/util}/AsynchronousDelayAction.d.ts +2 -2
  271. package/src/engine/intelligence/behavior/util/AsynchronousDelayAction.d.ts.map +1 -0
  272. package/src/{core/process/action → engine/intelligence/behavior/util}/AsynchronousDelayAction.js +55 -55
  273. package/src/engine/network/NetworkSession.d.ts +12 -1
  274. package/src/engine/network/NetworkSession.d.ts.map +1 -1
  275. package/src/engine/network/NetworkSession.js +52 -1
  276. package/src/engine/network/README.md +45 -0
  277. package/src/engine/network/convertPathToURL.d.ts +1 -8
  278. package/src/engine/network/convertPathToURL.d.ts.map +1 -1
  279. package/src/engine/network/convertPathToURL.js +2 -107
  280. package/src/engine/network/core/quantize/quantize_float.d.ts.map +1 -1
  281. package/src/engine/network/core/quantize/quantize_float.js +7 -0
  282. package/src/engine/network/core/quantize/quantize_position.d.ts.map +1 -1
  283. package/src/engine/network/core/quantize/quantize_position.js +12 -1
  284. package/src/engine/network/orchestrator/NetworkPeer.d.ts.map +1 -1
  285. package/src/engine/network/orchestrator/NetworkPeer.js +15 -1
  286. package/src/engine/network/replication/Replicator.d.ts +8 -0
  287. package/src/engine/network/replication/Replicator.d.ts.map +1 -1
  288. package/src/engine/network/replication/Replicator.js +48 -0
  289. package/src/engine/network/transport/Channel.d.ts.map +1 -1
  290. package/src/engine/network/transport/Channel.js +46 -12
  291. package/src/engine/network/transport/ReliableCommandPipeline.d.ts +16 -0
  292. package/src/engine/network/transport/ReliableCommandPipeline.d.ts.map +1 -1
  293. package/src/engine/network/transport/ReliableCommandPipeline.js +29 -0
  294. package/src/engine/network/transport/adapters/NodeUDPTransport.d.ts.map +1 -1
  295. package/src/engine/network/transport/adapters/NodeUDPTransport.js +7 -1
  296. package/src/engine/network/transport/fragments/packet_size.d.ts +5 -5
  297. package/src/engine/network/transport/fragments/packet_size.d.ts.map +1 -1
  298. package/src/engine/network/transport/fragments/packet_size.js +5 -5
  299. package/src/engine/physics/BULLET_REVIEW.md +1 -1
  300. package/src/engine/physics/JOLT_REVIEW.md +2 -2
  301. package/src/engine/physics/PLAN.md +1094 -945
  302. package/src/engine/physics/RAPIER_REVIEW.md +2 -2
  303. package/src/engine/physics/body/BodyStorage.d.ts +2 -12
  304. package/src/engine/physics/body/BodyStorage.d.ts.map +1 -1
  305. package/src/engine/physics/body/BodyStorage.js +406 -452
  306. package/src/engine/physics/body/SolverBodyState.d.ts.map +1 -1
  307. package/src/engine/physics/body/SolverBodyState.js +12 -3
  308. package/src/engine/physics/broadphase/compute_fat_world_aabb.d.ts +28 -3
  309. package/src/engine/physics/broadphase/compute_fat_world_aabb.d.ts.map +1 -1
  310. package/src/engine/physics/broadphase/compute_fat_world_aabb.js +60 -24
  311. package/src/engine/physics/broadphase/generate_pairs.d.ts +9 -5
  312. package/src/engine/physics/broadphase/generate_pairs.d.ts.map +1 -1
  313. package/src/engine/physics/broadphase/generate_pairs.js +52 -37
  314. package/src/engine/physics/ccd/linear_sweep.d.ts +15 -5
  315. package/src/engine/physics/ccd/linear_sweep.d.ts.map +1 -1
  316. package/src/engine/physics/ccd/linear_sweep.js +122 -40
  317. package/src/engine/physics/constraint/solve_constraints.d.ts.map +1 -1
  318. package/src/engine/physics/constraint/solve_constraints.js +830 -805
  319. package/src/engine/physics/contact/ManifoldStore.d.ts +91 -16
  320. package/src/engine/physics/contact/ManifoldStore.d.ts.map +1 -1
  321. package/src/engine/physics/contact/ManifoldStore.js +204 -60
  322. package/src/engine/physics/ecs/BodyKind.d.ts +7 -3
  323. package/src/engine/physics/ecs/BodyKind.d.ts.map +1 -1
  324. package/src/engine/physics/ecs/BodyKind.js +29 -25
  325. package/src/engine/physics/ecs/Collider.d.ts +7 -0
  326. package/src/engine/physics/ecs/Collider.d.ts.map +1 -1
  327. package/src/engine/physics/ecs/Collider.js +7 -0
  328. package/src/engine/physics/ecs/ColliderSerializationAdapter.js +1 -1
  329. package/src/engine/physics/ecs/PhysicsSystem.d.ts +110 -6
  330. package/src/engine/physics/ecs/PhysicsSystem.d.ts.map +1 -1
  331. package/src/engine/physics/ecs/PhysicsSystem.js +467 -45
  332. package/src/engine/physics/ecs/RigidBody.d.ts +20 -5
  333. package/src/engine/physics/ecs/RigidBody.d.ts.map +1 -1
  334. package/src/engine/physics/ecs/RigidBody.js +307 -286
  335. package/src/engine/physics/ecs/RigidBodyFlags.d.ts +6 -3
  336. package/src/engine/physics/ecs/RigidBodyFlags.d.ts.map +1 -1
  337. package/src/engine/physics/ecs/RigidBodyFlags.js +31 -28
  338. package/src/engine/physics/ecs/RigidBodySerializationAdapter.d.ts +12 -4
  339. package/src/engine/physics/ecs/RigidBodySerializationAdapter.d.ts.map +1 -1
  340. package/src/engine/physics/ecs/RigidBodySerializationAdapter.js +19 -5
  341. package/src/engine/physics/ecs/RigidBodySerializationUpgrader_0_1.d.ts +10 -0
  342. package/src/engine/physics/ecs/RigidBodySerializationUpgrader_0_1.d.ts.map +1 -0
  343. package/src/engine/physics/ecs/RigidBodySerializationUpgrader_0_1.js +37 -0
  344. package/src/engine/physics/ecs/find_non_finite_physics_state.d.ts +28 -0
  345. package/src/engine/physics/ecs/find_non_finite_physics_state.d.ts.map +1 -0
  346. package/src/engine/physics/ecs/find_non_finite_physics_state.js +76 -0
  347. package/src/engine/physics/events/ContactEventBuffer.d.ts +11 -0
  348. package/src/engine/physics/events/ContactEventBuffer.d.ts.map +1 -1
  349. package/src/engine/physics/events/ContactEventBuffer.js +40 -0
  350. package/src/engine/physics/events/diff_manifolds.d.ts +30 -13
  351. package/src/engine/physics/events/diff_manifolds.d.ts.map +1 -1
  352. package/src/engine/physics/events/diff_manifolds.js +87 -50
  353. package/src/engine/physics/fluid/FluidField.d.ts +45 -17
  354. package/src/engine/physics/fluid/FluidField.d.ts.map +1 -1
  355. package/src/engine/physics/fluid/FluidField.js +53 -23
  356. package/src/engine/physics/fluid/FluidSimulator.d.ts +141 -5
  357. package/src/engine/physics/fluid/FluidSimulator.d.ts.map +1 -1
  358. package/src/engine/physics/fluid/FluidSimulator.js +336 -43
  359. package/src/engine/physics/fluid/REVIEW_02_PLAN.md +114 -0
  360. package/src/engine/physics/fluid/ecs/FluidComponent.d.ts +4 -3
  361. package/src/engine/physics/fluid/ecs/FluidComponent.d.ts.map +1 -1
  362. package/src/engine/physics/fluid/ecs/FluidComponent.js +4 -3
  363. package/src/engine/physics/fluid/ecs/FluidSystem.d.ts +3 -3
  364. package/src/engine/physics/fluid/effector/AmbientWindFluidEffector.d.ts +41 -0
  365. package/src/engine/physics/fluid/effector/AmbientWindFluidEffector.d.ts.map +1 -0
  366. package/src/engine/physics/fluid/effector/AmbientWindFluidEffector.js +124 -0
  367. package/src/engine/physics/fluid/effector/WakeFluidEffector.d.ts +27 -8
  368. package/src/engine/physics/fluid/effector/WakeFluidEffector.d.ts.map +1 -1
  369. package/src/engine/physics/fluid/effector/WakeFluidEffector.js +67 -18
  370. package/src/engine/physics/fluid/solver/v3_grid_advect_maccormack_scalar.d.ts +42 -0
  371. package/src/engine/physics/fluid/solver/v3_grid_advect_maccormack_scalar.d.ts.map +1 -0
  372. package/src/engine/physics/fluid/solver/v3_grid_advect_maccormack_scalar.js +136 -0
  373. package/src/engine/physics/fluid/solver/v3_grid_advect_maccormack_velocity.d.ts +37 -0
  374. package/src/engine/physics/fluid/solver/v3_grid_advect_maccormack_velocity.d.ts.map +1 -0
  375. package/src/engine/physics/fluid/solver/v3_grid_advect_maccormack_velocity.js +169 -0
  376. package/src/engine/physics/fluid/solver/v3_grid_advect_sl_velocity.d.ts +36 -0
  377. package/src/engine/physics/fluid/solver/v3_grid_advect_sl_velocity.d.ts.map +1 -0
  378. package/src/engine/physics/fluid/solver/v3_grid_advect_sl_velocity.js +100 -0
  379. package/src/engine/physics/fluid/solver/v3_grid_apply_advection_forward.d.ts +6 -0
  380. package/src/engine/physics/fluid/solver/v3_grid_apply_advection_forward.d.ts.map +1 -1
  381. package/src/engine/physics/fluid/solver/v3_grid_apply_advection_forward.js +6 -0
  382. package/src/engine/physics/fluid/solver/v3_grid_apply_diffusion.d.ts +7 -2
  383. package/src/engine/physics/fluid/solver/v3_grid_apply_diffusion.d.ts.map +1 -1
  384. package/src/engine/physics/fluid/solver/v3_grid_apply_diffusion.js +17 -12
  385. package/src/engine/physics/fluid/solver/v3_grid_apply_vorticity_confinement.d.ts +42 -0
  386. package/src/engine/physics/fluid/solver/v3_grid_apply_vorticity_confinement.d.ts.map +1 -0
  387. package/src/engine/physics/fluid/solver/v3_grid_apply_vorticity_confinement.js +131 -0
  388. package/src/engine/physics/fluid/solver/v3_grid_compute_solid_neighbour_mask.d.ts +32 -22
  389. package/src/engine/physics/fluid/solver/v3_grid_compute_solid_neighbour_mask.d.ts.map +1 -1
  390. package/src/engine/physics/fluid/solver/v3_grid_compute_solid_neighbour_mask.js +43 -26
  391. package/src/engine/physics/fluid/solver/v3_grid_patch_edges_constant.d.ts +31 -0
  392. package/src/engine/physics/fluid/solver/v3_grid_patch_edges_constant.d.ts.map +1 -0
  393. package/src/engine/physics/fluid/solver/v3_grid_patch_edges_constant.js +77 -0
  394. package/src/engine/physics/fluid/solver/v3_grid_solve_pressure.d.ts +26 -19
  395. package/src/engine/physics/fluid/solver/v3_grid_solve_pressure.d.ts.map +1 -1
  396. package/src/engine/physics/fluid/solver/v3_grid_solve_pressure.js +46 -42
  397. package/src/engine/physics/fluid/solver/v3_grid_solve_pressure_pcg.d.ts +38 -10
  398. package/src/engine/physics/fluid/solver/v3_grid_solve_pressure_pcg.d.ts.map +1 -1
  399. package/src/engine/physics/fluid/solver/v3_grid_solve_pressure_pcg.js +158 -75
  400. package/src/engine/physics/fluid/solver/v3_grid_subtract_pressure_gradient.d.ts +22 -17
  401. package/src/engine/physics/fluid/solver/v3_grid_subtract_pressure_gradient.d.ts.map +1 -1
  402. package/src/engine/physics/fluid/solver/v3_grid_subtract_pressure_gradient.js +108 -96
  403. package/src/engine/physics/inertia/world_inverse_inertia.d.ts +30 -1
  404. package/src/engine/physics/inertia/world_inverse_inertia.d.ts.map +1 -1
  405. package/src/engine/physics/inertia/world_inverse_inertia.js +160 -116
  406. package/src/engine/physics/integration/integrate_position.js +97 -97
  407. package/src/engine/physics/island/IslandBuilder.d.ts +49 -8
  408. package/src/engine/physics/island/IslandBuilder.d.ts.map +1 -1
  409. package/src/engine/physics/island/IslandBuilder.js +93 -14
  410. package/src/engine/physics/narrowphase/box_box_manifold.d.ts.map +1 -1
  411. package/src/engine/physics/narrowphase/box_box_manifold.js +683 -673
  412. package/src/engine/physics/narrowphase/box_triangle_contact.d.ts.map +1 -1
  413. package/src/engine/physics/narrowphase/box_triangle_contact.js +899 -749
  414. package/src/engine/physics/narrowphase/capsule_contacts.d.ts +27 -0
  415. package/src/engine/physics/narrowphase/capsule_contacts.d.ts.map +1 -1
  416. package/src/engine/physics/narrowphase/capsule_contacts.js +624 -459
  417. package/src/engine/physics/narrowphase/capsule_triangle_contact.d.ts.map +1 -1
  418. package/src/engine/physics/narrowphase/capsule_triangle_contact.js +58 -38
  419. package/src/engine/physics/narrowphase/compute_penetration.d.ts.map +1 -1
  420. package/src/engine/physics/narrowphase/compute_penetration.js +369 -325
  421. package/src/engine/physics/narrowphase/convex_convex_manifold.d.ts +3 -1
  422. package/src/engine/physics/narrowphase/convex_convex_manifold.d.ts.map +1 -1
  423. package/src/engine/physics/narrowphase/convex_convex_manifold.js +568 -422
  424. package/src/engine/physics/narrowphase/decomposition/heightmap_enumerate_triangles.d.ts +6 -3
  425. package/src/engine/physics/narrowphase/decomposition/heightmap_enumerate_triangles.d.ts.map +1 -1
  426. package/src/engine/physics/narrowphase/decomposition/heightmap_enumerate_triangles.js +66 -10
  427. package/src/engine/physics/narrowphase/decomposition/mesh_enumerate_triangles.d.ts +4 -1
  428. package/src/engine/physics/narrowphase/decomposition/mesh_enumerate_triangles.d.ts.map +1 -1
  429. package/src/engine/physics/narrowphase/decomposition/mesh_enumerate_triangles.js +97 -94
  430. package/src/engine/physics/narrowphase/mesh_mesh_tet_manifold.js +117 -117
  431. package/src/engine/physics/narrowphase/narrowphase_step.d.ts.map +1 -1
  432. package/src/engine/physics/narrowphase/narrowphase_step.js +1738 -1739
  433. package/src/engine/physics/narrowphase/reduce_manifold_contacts.d.ts +14 -7
  434. package/src/engine/physics/narrowphase/reduce_manifold_contacts.d.ts.map +1 -1
  435. package/src/engine/physics/narrowphase/reduce_manifold_contacts.js +74 -69
  436. package/src/engine/physics/persistence/solver_caches.d.ts +20 -0
  437. package/src/engine/physics/persistence/solver_caches.d.ts.map +1 -0
  438. package/src/engine/physics/persistence/solver_caches.js +309 -0
  439. package/src/engine/physics/queries/overlap_shape.d.ts.map +1 -1
  440. package/src/engine/physics/queries/overlap_shape.js +187 -184
  441. package/src/engine/physics/queries/raycast.d.ts +3 -2
  442. package/src/engine/physics/queries/raycast.d.ts.map +1 -1
  443. package/src/engine/physics/queries/raycast.js +37 -11
  444. package/src/engine/physics/queries/shape_cast.d.ts +18 -5
  445. package/src/engine/physics/queries/shape_cast.d.ts.map +1 -1
  446. package/src/engine/physics/queries/shape_cast.js +417 -393
  447. package/src/engine/physics/solver/solve_contacts.d.ts +22 -6
  448. package/src/engine/physics/solver/solve_contacts.d.ts.map +1 -1
  449. package/src/engine/physics/solver/solve_contacts.js +1482 -1338
  450. package/src/engine/physics/vehicle/RaycastVehicle.d.ts.map +1 -1
  451. package/src/engine/physics/vehicle/RaycastVehicle.js +344 -339
  452. package/src/engine/ui/DraggableAspect.d.ts +12 -3
  453. package/src/engine/ui/DraggableAspect.d.ts.map +1 -1
  454. package/src/engine/ui/DraggableAspect.js +115 -83
  455. package/src/generation/COORDINATES.md +54 -0
  456. package/src/generation/GridTaskGroup.js +2 -2
  457. package/src/generation/REVIEW_01_ACTION_PLAN.md +628 -0
  458. package/src/generation/automata/CaveGeneratorCellularAutomata.d.ts +9 -1
  459. package/src/generation/automata/CaveGeneratorCellularAutomata.d.ts.map +1 -1
  460. package/src/generation/automata/CaveGeneratorCellularAutomata.js +79 -59
  461. package/src/generation/automata/CellularAutomata.d.ts +6 -3
  462. package/src/generation/automata/CellularAutomata.d.ts.map +1 -1
  463. package/src/generation/automata/CellularAutomata.js +22 -19
  464. package/src/generation/filtering/CellFilter.d.ts +17 -0
  465. package/src/generation/filtering/CellFilter.d.ts.map +1 -1
  466. package/src/generation/filtering/CellFilter.js +117 -77
  467. package/src/generation/filtering/CellFilterCellMatcher.d.ts.map +1 -1
  468. package/src/generation/filtering/CellFilterCellMatcher.js +2 -0
  469. package/src/generation/filtering/boolean/CellFilterLiteralBoolean.d.ts +5 -0
  470. package/src/generation/filtering/boolean/CellFilterLiteralBoolean.d.ts.map +1 -1
  471. package/src/generation/filtering/boolean/CellFilterLiteralBoolean.js +15 -0
  472. package/src/generation/filtering/core/CellFilterBinaryOperation.d.ts +0 -1
  473. package/src/generation/filtering/core/CellFilterBinaryOperation.d.ts.map +1 -1
  474. package/src/generation/filtering/core/CellFilterBinaryOperation.js +37 -50
  475. package/src/generation/filtering/core/CellFilterOperationTertiary.d.ts +0 -1
  476. package/src/generation/filtering/core/CellFilterOperationTertiary.d.ts.map +1 -1
  477. package/src/generation/filtering/core/CellFilterOperationTertiary.js +43 -59
  478. package/src/generation/filtering/core/CellFilterUnaryOperation.d.ts +0 -1
  479. package/src/generation/filtering/core/CellFilterUnaryOperation.d.ts.map +1 -1
  480. package/src/generation/filtering/core/CellFilterUnaryOperation.js +29 -33
  481. package/src/generation/filtering/numeric/CellFilterCache.d.ts +1 -0
  482. package/src/generation/filtering/numeric/CellFilterCache.d.ts.map +1 -1
  483. package/src/generation/filtering/numeric/complex/CellFilterAngleToNormal.d.ts +3 -2
  484. package/src/generation/filtering/numeric/complex/CellFilterAngleToNormal.d.ts.map +1 -1
  485. package/src/generation/filtering/numeric/complex/CellFilterAngleToNormal.js +9 -35
  486. package/src/generation/filtering/numeric/complex/CellFilterCurvature.d.ts +0 -1
  487. package/src/generation/filtering/numeric/complex/CellFilterCurvature.d.ts.map +1 -1
  488. package/src/generation/filtering/numeric/complex/CellFilterCurvature.js +19 -43
  489. package/src/generation/filtering/numeric/complex/CellFilterFXAA.d.ts +0 -1
  490. package/src/generation/filtering/numeric/complex/CellFilterFXAA.d.ts.map +1 -1
  491. package/src/generation/filtering/numeric/complex/CellFilterFXAA.js +2 -6
  492. package/src/generation/filtering/numeric/complex/CellFilterGaussianBlur.d.ts.map +1 -1
  493. package/src/generation/filtering/numeric/complex/CellFilterGaussianBlur.js +9 -12
  494. package/src/generation/filtering/numeric/complex/CellFilterSimplexNoise.d.ts.map +1 -1
  495. package/src/generation/filtering/numeric/complex/CellFilterSimplexNoise.js +2 -1
  496. package/src/generation/filtering/numeric/complex/CellFilterSobel.d.ts +0 -1
  497. package/src/generation/filtering/numeric/complex/CellFilterSobel.d.ts.map +1 -1
  498. package/src/generation/filtering/numeric/complex/CellFilterSobel.js +2 -6
  499. package/src/generation/filtering/numeric/math/CellFilterInverseLerp.d.ts +5 -4
  500. package/src/generation/filtering/numeric/math/CellFilterInverseLerp.d.ts.map +1 -1
  501. package/src/generation/filtering/numeric/math/CellFilterInverseLerp.js +5 -4
  502. package/src/generation/filtering/numeric/process/computeFilterSurfaceNormal.d.ts +17 -0
  503. package/src/generation/filtering/numeric/process/computeFilterSurfaceNormal.d.ts.map +1 -0
  504. package/src/generation/filtering/numeric/process/computeFilterSurfaceNormal.js +42 -0
  505. package/src/generation/filtering/numeric/sampling/AbstractCellFilterSampleGridLayer.d.ts.map +1 -1
  506. package/src/generation/filtering/numeric/sampling/AbstractCellFilterSampleGridLayer.js +7 -1
  507. package/src/generation/filtering/numeric/util/populateSampler2DFromCellFilter.d.ts.map +1 -1
  508. package/src/generation/filtering/numeric/util/populateSampler2DFromCellFilter.js +7 -10
  509. package/src/generation/filtering/numeric/util/sampler_from_filter.d.ts.map +1 -1
  510. package/src/generation/filtering/numeric/util/sampler_from_filter.js +2 -1
  511. package/src/generation/grid/GridData.d.ts.map +1 -1
  512. package/src/generation/grid/GridData.js +14 -1
  513. package/src/generation/grid/actions/ContinuousGridCellAction.d.ts +10 -3
  514. package/src/generation/grid/actions/ContinuousGridCellAction.d.ts.map +1 -1
  515. package/src/generation/grid/actions/ContinuousGridCellAction.js +18 -3
  516. package/src/generation/grid/actions/ContinuousGridCellActionSetTerrainHeight.d.ts +11 -1
  517. package/src/generation/grid/actions/ContinuousGridCellActionSetTerrainHeight.d.ts.map +1 -1
  518. package/src/generation/grid/actions/ContinuousGridCellActionSetTerrainHeight.js +13 -3
  519. package/src/generation/grid/actions/ContinuousGridCellActionSetTerrainObstacle.d.ts +1 -1
  520. package/src/generation/grid/actions/ContinuousGridCellActionSetTerrainObstacle.js +2 -2
  521. package/src/generation/grid/actions/ContinuousGridCellActionWriteObstacle.d.ts +1 -1
  522. package/src/generation/grid/actions/ContinuousGridCellActionWriteObstacle.d.ts.map +1 -1
  523. package/src/generation/grid/actions/ContinuousGridCellActionWriteObstacle.js +4 -6
  524. package/src/generation/grid/coords/grid_to_texel.d.ts +9 -0
  525. package/src/generation/grid/coords/grid_to_texel.d.ts.map +1 -0
  526. package/src/generation/grid/coords/grid_to_texel.js +10 -0
  527. package/src/generation/grid/coords/texel_to_grid.d.ts +9 -0
  528. package/src/generation/grid/coords/texel_to_grid.d.ts.map +1 -0
  529. package/src/generation/grid/coords/texel_to_grid.js +10 -0
  530. package/src/generation/grid/generation/GridTaskApplyActionToCells.d.ts +2 -2
  531. package/src/generation/grid/generation/GridTaskApplyActionToCells.d.ts.map +1 -1
  532. package/src/generation/grid/generation/GridTaskApplyActionToCells.js +10 -6
  533. package/src/generation/grid/generation/GridTaskDensityMarkerDistribution.d.ts.map +1 -1
  534. package/src/generation/grid/generation/GridTaskDensityMarkerDistribution.js +20 -21
  535. package/src/generation/grid/generation/GridTaskExecuteRuleTimes.d.ts +7 -0
  536. package/src/generation/grid/generation/GridTaskExecuteRuleTimes.d.ts.map +1 -1
  537. package/src/generation/grid/generation/GridTaskExecuteRuleTimes.js +18 -10
  538. package/src/generation/grid/generation/discrete/GridTaskCellularAutomata.d.ts.map +1 -1
  539. package/src/generation/grid/generation/discrete/GridTaskCellularAutomata.js +16 -7
  540. package/src/generation/grid/generation/discrete/GridTaskConnectRooms.d.ts +5 -3
  541. package/src/generation/grid/generation/discrete/GridTaskConnectRooms.d.ts.map +1 -1
  542. package/src/generation/grid/generation/discrete/GridTaskConnectRooms.js +26 -23
  543. package/src/generation/grid/generation/discrete/layer/GridTaskBuildSourceDistanceMap.d.ts.map +1 -1
  544. package/src/generation/grid/generation/discrete/layer/GridTaskBuildSourceDistanceMap.js +10 -1
  545. package/src/generation/grid/generation/grid/select/CellSupplierBestN.d.ts.map +1 -1
  546. package/src/generation/grid/generation/grid/select/CellSupplierBestN.js +4 -0
  547. package/src/generation/grid/generation/road/GridTaskGenerateRoads.d.ts +15 -8
  548. package/src/generation/grid/generation/road/GridTaskGenerateRoads.d.ts.map +1 -1
  549. package/src/generation/grid/generation/road/GridTaskGenerateRoads.js +89 -92
  550. package/src/generation/markers/GridActionRuleSet.d.ts.map +1 -1
  551. package/src/generation/markers/GridActionRuleSet.js +10 -2
  552. package/src/generation/markers/GridCellActionPlaceMarker.d.ts +11 -0
  553. package/src/generation/markers/GridCellActionPlaceMarker.d.ts.map +1 -1
  554. package/src/generation/markers/GridCellActionPlaceMarker.js +20 -3
  555. package/src/generation/markers/GridCellActionPlaceMarkerGroup.d.ts +3 -1
  556. package/src/generation/markers/GridCellActionPlaceMarkerGroup.d.ts.map +1 -1
  557. package/src/generation/markers/GridCellActionPlaceMarkerGroup.js +9 -2
  558. package/src/generation/markers/MarkerNode.d.ts +8 -3
  559. package/src/generation/markers/MarkerNode.d.ts.map +1 -1
  560. package/src/generation/markers/MarkerNode.js +12 -5
  561. package/src/generation/markers/actions/MarkerNodeActionEntityPlacement.js +1 -1
  562. package/src/generation/markers/actions/placement/MarkerNodeEntityProcessor.d.ts +1 -1
  563. package/src/generation/markers/actions/placement/MarkerNodeEntityProcessor.d.ts.map +1 -1
  564. package/src/generation/markers/actions/placement/MarkerNodeEntityProcessor.js +1 -1
  565. package/src/generation/markers/actions/placement/MarkerNodeEntityProcessorClingToTerrain.d.ts +1 -1
  566. package/src/generation/markers/actions/placement/MarkerNodeEntityProcessorClingToTerrain.d.ts.map +1 -1
  567. package/src/generation/markers/actions/placement/MarkerNodeEntityProcessorClingToTerrain.js +1 -1
  568. package/src/generation/markers/actions/placement/MarkerNodeEntityProcessorRandomRotation.d.ts +1 -1
  569. package/src/generation/markers/actions/placement/MarkerNodeEntityProcessorRandomRotation.d.ts.map +1 -1
  570. package/src/generation/markers/actions/placement/MarkerNodeEntityProcessorRandomRotation.js +2 -2
  571. package/src/generation/markers/actions/placement/MarkerNodeEntityProcessorSequence.d.ts +1 -1
  572. package/src/generation/markers/actions/placement/MarkerNodeEntityProcessorSequence.d.ts.map +1 -1
  573. package/src/generation/markers/actions/placement/MarkerNodeEntityProcessorSequence.js +2 -2
  574. package/src/generation/markers/actions/probability/MarkerNodeActionSelectWeighted.d.ts.map +1 -1
  575. package/src/generation/markers/actions/probability/MarkerNodeActionSelectWeighted.js +6 -4
  576. package/src/generation/markers/actions/probability/MarkerNodeActionWeightedElement.d.ts.map +1 -1
  577. package/src/generation/markers/actions/probability/MarkerNodeActionWeightedElement.js +1 -3
  578. package/src/generation/markers/actions/terrain/MarkerNodeActionPaintTerrain.d.ts.map +1 -1
  579. package/src/generation/markers/actions/terrain/MarkerNodeActionPaintTerrain.js +12 -11
  580. package/src/generation/markers/matcher/MarkerNodeMatcherAnd.js +2 -2
  581. package/src/generation/markers/transform/MarkerNodeTransformer.d.ts +4 -1
  582. package/src/generation/markers/transform/MarkerNodeTransformer.d.ts.map +1 -1
  583. package/src/generation/markers/transform/MarkerNodeTransformer.js +4 -1
  584. package/src/generation/markers/transform/MarkerNodeTransformerAddPositionYFromFilter.d.ts.map +1 -1
  585. package/src/generation/markers/transform/MarkerNodeTransformerAddPositionYFromFilter.js +1 -3
  586. package/src/generation/markers/transform/MarkerNodeTransformerOffsetPosition.d.ts +5 -0
  587. package/src/generation/markers/transform/MarkerNodeTransformerOffsetPosition.d.ts.map +1 -1
  588. package/src/generation/markers/transform/MarkerNodeTransformerOffsetPosition.js +15 -0
  589. package/src/generation/markers/transform/MarkerNodeTransformerRecordProperty.d.ts.map +1 -1
  590. package/src/generation/markers/transform/MarkerNodeTransformerRecordProperty.js +1 -3
  591. package/src/generation/markers/transform/MarkerNodeTransformerYRotateByFilter.d.ts.map +1 -1
  592. package/src/generation/markers/transform/MarkerNodeTransformerYRotateByFilter.js +2 -4
  593. package/src/generation/markers/transform/MarkerNodeTransformerYRotateByFilterGradient.d.ts.map +1 -1
  594. package/src/generation/markers/transform/MarkerNodeTransformerYRotateByFilterGradient.js +1 -3
  595. package/src/generation/placement/GridCellPlacementRule.d.ts.map +1 -1
  596. package/src/generation/placement/GridCellPlacementRule.js +1 -3
  597. package/src/generation/placement/action/GridCellActionWriteFilterToLayer.d.ts.map +1 -1
  598. package/src/generation/placement/action/GridCellActionWriteFilterToLayer.js +8 -10
  599. package/src/generation/placement/action/random/weighted/CellActionSelectWeightedRandom.d.ts.map +1 -1
  600. package/src/generation/placement/action/random/weighted/CellActionSelectWeightedRandom.js +6 -4
  601. package/src/generation/placement/action/random/weighted/WeightedGridCellAction.d.ts.map +1 -1
  602. package/src/generation/placement/action/random/weighted/WeightedGridCellAction.js +1 -3
  603. package/src/generation/rules/CellMatcher.d.ts +3 -1
  604. package/src/generation/rules/CellMatcher.d.ts.map +1 -1
  605. package/src/generation/rules/CellMatcher.js +3 -1
  606. package/src/generation/rules/CellMatcherFromFilter.d.ts.map +1 -1
  607. package/src/generation/rules/CellMatcherFromFilter.js +1 -3
  608. package/src/generation/rules/CellMatcherLayerBitMaskTest.d.ts.map +1 -1
  609. package/src/generation/rules/CellMatcherLayerBitMaskTest.js +6 -20
  610. package/src/generation/test_support/executeTaskTreeSync.d.ts +9 -0
  611. package/src/generation/test_support/executeTaskTreeSync.d.ts.map +1 -0
  612. package/src/generation/test_support/executeTaskTreeSync.js +78 -0
  613. package/src/generation/theme/TerrainLayerRuleAggregator.d.ts +2 -1
  614. package/src/generation/theme/TerrainLayerRuleAggregator.d.ts.map +1 -1
  615. package/src/generation/theme/TerrainLayerRuleAggregator.js +9 -6
  616. package/src/generation/theme/Theme.d.ts +1 -1
  617. package/src/generation/theme/Theme.d.ts.map +1 -1
  618. package/src/generation/theme/Theme.js +2 -2
  619. package/src/generation/theme/ThemeEngine.d.ts +3 -3
  620. package/src/generation/theme/ThemeEngine.d.ts.map +1 -1
  621. package/src/generation/theme/ThemeEngine.js +26 -16
  622. package/src/generation/theme/cell/CellProcessingRule.d.ts +3 -3
  623. package/src/generation/theme/cell/CellProcessingRule.d.ts.map +1 -1
  624. package/src/generation/theme/cell/CellProcessingRule.js +6 -10
  625. package/src/generation/theme/cell/CellProcessingRuleSet.d.ts +1 -1
  626. package/src/generation/theme/cell/CellProcessingRuleSet.d.ts.map +1 -1
  627. package/src/generation/theme/cell/CellProcessingRuleSet.js +2 -2
  628. package/src/view/common/ListView.js +1 -1
  629. package/src/view/elements/BottomLeftResizeHandleView.d.ts.map +1 -1
  630. package/src/view/elements/BottomLeftResizeHandleView.js +13 -5
  631. package/src/core/font/FontAsset.d.ts.map +0 -1
  632. package/src/core/font/FontAssetLoader.d.ts.map +0 -1
  633. package/src/core/geom/3d/shape/util/shape_to_visual_entity.d.ts.map +0 -1
  634. package/src/core/geom/3d/tetrahedra/visualize_tetrahedral_mesh.d.ts.map +0 -1
  635. package/src/core/process/action/AsynchronousDelayAction.d.ts.map +0 -1
  636. package/src/engine/physics/computeInterceptPoint.d.ts.map +0 -1
  637. package/src/engine/physics/fluid/solver/optimal_sor_omega.d.ts.map +0 -1
  638. package/src/engine/physics/gjk/gjk.d.ts.map +0 -1
  639. package/src/engine/physics/gjk/gjk_epa_penetration.d.ts.map +0 -1
  640. package/src/engine/physics/gjk/minkowski_support.d.ts.map +0 -1
  641. package/src/engine/physics/gjk/mpr.d.ts.map +0 -1
  642. package/src/engine/physics/integration/quat_integrate.d.ts.map +0 -1
  643. package/src/engine/physics/island/union_find.d.ts.map +0 -1
  644. package/src/engine/physics/narrowphase/clip_against_axis_uv.d.ts.map +0 -1
  645. package/src/engine/physics/narrowphase/decomposition/aabb_world_to_local.d.ts.map +0 -1
  646. package/src/generation/grid/generation/discrete/layer/GridTaskDistanceToMarkers.d.ts +0 -21
  647. package/src/generation/grid/generation/discrete/layer/GridTaskDistanceToMarkers.d.ts.map +0 -1
  648. package/src/generation/grid/generation/discrete/layer/GridTaskDistanceToMarkers.js +0 -68
  649. package/src/generation/grid/generation/grid/GridTaskGridAlignedNodeGenerator.d.ts +0 -10
  650. package/src/generation/grid/generation/grid/GridTaskGridAlignedNodeGenerator.d.ts.map +0 -1
  651. package/src/generation/grid/generation/grid/GridTaskGridAlignedNodeGenerator.js +0 -17
  652. /package/src/{engine/physics → core/geom/3d}/gjk/NOTES.md +0 -0
  653. /package/src/{engine/physics → core/geom/3d}/gjk/gjk.d.ts +0 -0
  654. /package/src/{engine/physics → core/math/physics/kinematics}/computeInterceptPoint.d.ts +0 -0
@@ -1,59 +1,43 @@
1
- import { CellFilter } from "../CellFilter.js";
2
-
3
- export class CellFilterOperationTertiary extends CellFilter {
4
-
5
- /**
6
- *
7
- * @type {CellFilter}
8
- */
9
- a = null;
10
- /**
11
- *
12
- * @type {CellFilter}
13
- */
14
- b = null;
15
- /**
16
- *
17
- * @type {CellFilter}
18
- */
19
- c = null;
20
-
21
- /**
22
- *
23
- * @param {number} a
24
- * @param {number} b
25
- * @param {number} c
26
- * @returns {number}
27
- */
28
- operation(a, b, c) {
29
- throw new Error('Not implemented');
30
- }
31
-
32
- initialize(grid, seed) {
33
- if (this.initialized) {
34
- return;
35
- }
36
-
37
- super.initialize(grid, seed);
38
-
39
- if (!this.a.initialized) {
40
- this.a.initialize(grid, seed);
41
- }
42
-
43
- if (!this.b.initialized) {
44
- this.b.initialize(grid, seed);
45
- }
46
-
47
- if (!this.c.initialized) {
48
- this.c.initialize(grid, seed);
49
- }
50
- }
51
-
52
- execute(grid, x, y, rotation) {
53
- const a = this.a.execute(grid, x, y, rotation);
54
- const b = this.b.execute(grid, x, y, rotation);
55
- const c = this.c.execute(grid, x, y, rotation);
56
-
57
- return this.operation(a, b, c);
58
- }
59
- }
1
+ import { CellFilter } from "../CellFilter.js";
2
+
3
+ export class CellFilterOperationTertiary extends CellFilter {
4
+
5
+ /**
6
+ *
7
+ * @type {CellFilter}
8
+ */
9
+ a = null;
10
+ /**
11
+ *
12
+ * @type {CellFilter}
13
+ */
14
+ b = null;
15
+ /**
16
+ *
17
+ * @type {CellFilter}
18
+ */
19
+ c = null;
20
+
21
+ get children() {
22
+ return [this.a, this.b, this.c];
23
+ }
24
+
25
+ /**
26
+ *
27
+ * @param {number} a
28
+ * @param {number} b
29
+ * @param {number} c
30
+ * @returns {number}
31
+ */
32
+ operation(a, b, c) {
33
+ throw new Error('Not implemented');
34
+ }
35
+
36
+ execute(grid, x, y, rotation) {
37
+ const a = this.a.execute(grid, x, y, rotation);
38
+ const b = this.b.execute(grid, x, y, rotation);
39
+ const c = this.c.execute(grid, x, y, rotation);
40
+
41
+ return this.operation(a, b, c);
42
+ }
43
+ }
@@ -10,7 +10,6 @@ export class CellFilterUnaryOperation extends CellFilter {
10
10
  * @returns {number}
11
11
  */
12
12
  operation(v: number): number;
13
- initialize(grid: any, seed: any): void;
14
13
  execute(grid: any, x: any, y: any, rotation: any): number;
15
14
  }
16
15
  import { CellFilter } from "../CellFilter.js";
@@ -1 +1 @@
1
- {"version":3,"file":"CellFilterUnaryOperation.d.ts","sourceRoot":"","sources":["../../../../../src/generation/filtering/core/CellFilterUnaryOperation.js"],"names":[],"mappings":"AAEA;IAEI;;;OAGG;IACH,QAFU,UAAU,CAEN;IAEd;;;;OAIG;IACH,aAHW,MAAM,GACJ,MAAM,CAIlB;IAED,uCAMC;IAED,0DAIC;CACJ;2BAhC0B,kBAAkB"}
1
+ {"version":3,"file":"CellFilterUnaryOperation.d.ts","sourceRoot":"","sources":["../../../../../src/generation/filtering/core/CellFilterUnaryOperation.js"],"names":[],"mappings":"AAEA;IAEI;;;OAGG;IACH,QAFU,UAAU,CAEN;IAMd;;;;OAIG;IACH,aAHW,MAAM,GACJ,MAAM,CAIlB;IAED,0DAIC;CACJ;2BA5B0B,kBAAkB"}
@@ -1,33 +1,29 @@
1
- import { CellFilter } from "../CellFilter.js";
2
-
3
- export class CellFilterUnaryOperation extends CellFilter {
4
-
5
- /**
6
- *
7
- * @type {CellFilter}
8
- */
9
- source = null;
10
-
11
- /**
12
- *
13
- * @param {number} v
14
- * @returns {number}
15
- */
16
- operation(v) {
17
- throw new Error('Not implemented');
18
- }
19
-
20
- initialize(grid, seed) {
21
- super.initialize(grid, seed);
22
-
23
- if (!this.source.initialized) {
24
- this.source.initialize(grid, seed);
25
- }
26
- }
27
-
28
- execute(grid, x, y, rotation) {
29
- const s = this.source.execute(grid, x, y, rotation);
30
-
31
- return this.operation(s);
32
- }
33
- }
1
+ import { CellFilter } from "../CellFilter.js";
2
+
3
+ export class CellFilterUnaryOperation extends CellFilter {
4
+
5
+ /**
6
+ *
7
+ * @type {CellFilter}
8
+ */
9
+ source = null;
10
+
11
+ get children() {
12
+ return [this.source];
13
+ }
14
+
15
+ /**
16
+ *
17
+ * @param {number} v
18
+ * @returns {number}
19
+ */
20
+ operation(v) {
21
+ throw new Error('Not implemented');
22
+ }
23
+
24
+ execute(grid, x, y, rotation) {
25
+ const s = this.source.execute(grid, x, y, rotation);
26
+
27
+ return this.operation(s);
28
+ }
29
+ }
@@ -17,6 +17,7 @@ export class CellFilterCache extends CellFilterUnaryOperation {
17
17
  * @type {number}
18
18
  */
19
19
  scale: number;
20
+ initialize(grid: any, seed: any): void;
20
21
  }
21
22
  import { CellFilterUnaryOperation } from "../core/CellFilterUnaryOperation.js";
22
23
  //# sourceMappingURL=CellFilterCache.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"CellFilterCache.d.ts","sourceRoot":"","sources":["../../../../../src/generation/filtering/numeric/CellFilterCache.js"],"names":[],"mappings":"AAIA;IAeI;;;;;OAKG;IACH,wCAHW,MAAM,GACJ,eAAe,CAW3B;IA5BD;;;;OAIG;IACH,gBAAqC;IAErC;;;OAGG;IACH,OAFU,MAAM,CAEN;CA0Db;yCAzEwC,qCAAqC"}
1
+ {"version":3,"file":"CellFilterCache.d.ts","sourceRoot":"","sources":["../../../../../src/generation/filtering/numeric/CellFilterCache.js"],"names":[],"mappings":"AAIA;IAeI;;;;;OAKG;IACH,wCAHW,MAAM,GACJ,eAAe,CAW3B;IA5BD;;;;OAIG;IACH,gBAAqC;IAErC;;;OAGG;IACH,OAFU,MAAM,CAEN;IAmBV,uCAkCC;CAKJ;yCAzEwC,qCAAqC"}
@@ -1,5 +1,7 @@
1
1
  /**
2
- * Builds surface normal of another filter, and then computes the angle to a fixed 3d vector
2
+ * Builds surface normal of another filter, and then computes the angle to a fixed 3d vector.
3
+ * Normal convention is that of {@link computeFilterSurfaceNormal}: z is up, a surface rising
4
+ * along +x has a normal tilting towards -x.
3
5
  */
4
6
  export class CellFilterAngleToNormal extends CellFilter {
5
7
  /**
@@ -19,7 +21,6 @@ export class CellFilterAngleToNormal extends CellFilter {
19
21
  * @type {CellFilter}
20
22
  */
21
23
  surface: CellFilter;
22
- initialize(grid: any, seed: any): void;
23
24
  execute(grid: any, x: any, y: any, rotation: any): number;
24
25
  }
25
26
  import { CellFilter } from "../../CellFilter.js";
@@ -1 +1 @@
1
- {"version":3,"file":"CellFilterAngleToNormal.d.ts","sourceRoot":"","sources":["../../../../../../src/generation/filtering/numeric/complex/CellFilterAngleToNormal.js"],"names":[],"mappings":"AAWA;;GAEG;AACH;IAiBI;;;;;OAKG;IACH,qBAJW,UAAU,cACV,OAAO,GACL,uBAAuB,CAWnC;IA5BG;;;OAGG;IACH,WAFU,OAAO,CAEoB;IAErC;;;OAGG;IACH,SAFU,UAAU,CAED;IAoBvB,uCAMC;IAED,0DA2BC;CACJ;2BApF0B,qBAAqB;oBAC5B,kCAAkC"}
1
+ {"version":3,"file":"CellFilterAngleToNormal.d.ts","sourceRoot":"","sources":["../../../../../../src/generation/filtering/numeric/complex/CellFilterAngleToNormal.js"],"names":[],"mappings":"AAQA;;;;GAIG;AACH;IAiBI;;;;;OAKG;IACH,qBAJW,UAAU,cACV,OAAO,GACL,uBAAuB,CAWnC;IA5BG;;;OAGG;IACH,WAFU,OAAO,CAEoB;IAErC;;;OAGG;IACH,SAFU,UAAU,CAED;IAwBvB,0DAMC;CACJ;2BA1D0B,qBAAqB;oBAC5B,kCAAkC"}
@@ -2,15 +2,14 @@ import { CellFilter } from "../../CellFilter.js";
2
2
  import Vector3 from "../../../../core/geom/Vector3.js";
3
3
  import { assert } from "../../../../core/assert.js";
4
4
  import { v3_angle_between } from "../../../../core/geom/vec3/v3_angle_between.js";
5
+ import { computeFilterSurfaceNormal } from "../process/computeFilterSurfaceNormal.js";
5
6
 
6
- /**
7
- * Distance from the reference point where support points will be sampled to compute derivative
8
- * @type {number}
9
- */
10
- const DERIVATIVE_OFFSET = 1;
7
+ const normal = [];
11
8
 
12
9
  /**
13
- * Builds surface normal of another filter, and then computes the angle to a fixed 3d vector
10
+ * Builds surface normal of another filter, and then computes the angle to a fixed 3d vector.
11
+ * Normal convention is that of {@link computeFilterSurfaceNormal}: z is up, a surface rising
12
+ * along +x has a normal tilting towards -x.
14
13
  */
15
14
  export class CellFilterAngleToNormal extends CellFilter {
16
15
  constructor() {
@@ -46,40 +45,15 @@ export class CellFilterAngleToNormal extends CellFilter {
46
45
  return r;
47
46
  }
48
47
 
49
- initialize(grid, seed) {
50
- if (!this.surface.initialized) {
51
- this.surface.initialize(grid, seed);
52
- }
53
-
54
- super.initialize(grid, seed);
48
+ get children() {
49
+ return [this.surface];
55
50
  }
56
51
 
57
52
  execute(grid, x, y, rotation) {
58
- const filter = this.surface;
59
-
60
- //read surrounding points
61
- const top = filter.execute(grid, x, y - DERIVATIVE_OFFSET, 0);
62
-
63
- const left = filter.execute(grid, x - DERIVATIVE_OFFSET, y, 0);
64
- const right = filter.execute(grid, x + DERIVATIVE_OFFSET, y, 0);
65
-
66
- const bottom = filter.execute(grid, x, y + DERIVATIVE_OFFSET, 0);
67
-
68
- // compute gradients
69
- const dX = (right) - (left);
70
- const dY = (bottom) - (top);
71
-
72
- //normalize vector
73
- const magnitude = Math.sqrt(dX * dX + dY * dY + 4);
74
-
75
- const _x = dX / magnitude;
76
- const _y = dY / magnitude;
77
- const _z = 2 / magnitude;
53
+ computeFilterSurfaceNormal(normal, this.surface, grid, x, y);
78
54
 
79
55
  const reference = this.reference;
80
56
 
81
- const angle = v3_angle_between(reference.x, reference.y, reference.z, _x, _y, _z);
82
-
83
- return angle;
57
+ return v3_angle_between(reference.x, reference.y, reference.z, normal[0], normal[1], normal[2]);
84
58
  }
85
59
  }
@@ -10,7 +10,6 @@ export class CellFilterCurvature extends CellFilter {
10
10
  * @type {CellFilter}
11
11
  */
12
12
  surface: CellFilter;
13
- initialize(grid: any, seed: any): void;
14
13
  /**
15
14
  *
16
15
  * @param grid
@@ -1 +1 @@
1
- {"version":3,"file":"CellFilterCurvature.d.ts","sourceRoot":"","sources":["../../../../../../src/generation/filtering/numeric/complex/CellFilterCurvature.js"],"names":[],"mappings":"AA4DA;IAUI;;;;OAIG;IACH,qBAHW,UAAU,GACT,mBAAmB,CAW9B;IArBG;;;OAGG;IACH,SAFU,UAAU,CAEL;IAmBnB,uCAMC;IAED;;;;;;;OAOG;IACH,mDAFY,MAAM,CAoBjB;CACJ;2BAxH0B,qBAAqB"}
1
+ {"version":3,"file":"CellFilterCurvature.d.ts","sourceRoot":"","sources":["../../../../../../src/generation/filtering/numeric/complex/CellFilterCurvature.js"],"names":[],"mappings":"AAiCA;IAUI;;;;OAIG;IACH,qBAHW,UAAU,GACT,mBAAmB,CAW9B;IArBG;;;OAGG;IACH,SAFU,UAAU,CAEL;IAuBnB;;;;;;;OAOG;IACH,mDAFY,MAAM,CA2BjB;CACJ;2BAhG0B,qBAAqB"}
@@ -1,5 +1,6 @@
1
1
  import { assert } from "../../../../core/assert.js";
2
2
  import { CellFilter } from "../../CellFilter.js";
3
+ import { computeFilterSurfaceNormal } from "../process/computeFilterSurfaceNormal.js";
3
4
 
4
5
 
5
6
  /*
@@ -24,39 +25,11 @@ const xneg = [];
24
25
  const xpos = [];
25
26
 
26
27
  /**
27
- *
28
- * @param {GridData} grid
29
- * @param {number[]} result
30
- * @param {CellFilter} surface
31
- * @param {number} x
32
- * @param {number} y
28
+ * Guards against re-entrant use of the shared scratch arrays above, which would corrupt an
29
+ * in-flight computation (e.g. curvature of a filter graph that itself contains a curvature filter)
30
+ * @type {boolean}
33
31
  */
34
- function computeNormal(grid, result, surface, x, y) {
35
-
36
-
37
- //read surrounding points
38
- const top = surface.execute(grid, x, y - 1, 0);
39
-
40
- const left = surface.execute(grid, x - 1, y, 0);
41
- const right = surface.execute(grid, x + 1, y, 0);
42
-
43
- const bottom = surface.execute(grid, x, y + 1, 0);
44
-
45
- // compute gradients
46
- const dX = (right) - (left);
47
- const dY = (bottom) - (top);
48
-
49
- //normalize vector
50
- const magnitude = Math.sqrt(dX * dX + dY * dY + 4);
51
-
52
- const _x = dX / magnitude;
53
- const _y = dY / magnitude;
54
- const _z = 2 / magnitude;
55
-
56
- result[0] = _x;
57
- result[1] = _y;
58
- result[2] = _z;
59
- }
32
+ let scratch_locked = false;
60
33
 
61
34
  export class CellFilterCurvature extends CellFilter {
62
35
 
@@ -84,12 +57,8 @@ export class CellFilterCurvature extends CellFilter {
84
57
  return r;
85
58
  }
86
59
 
87
- initialize(grid, seed) {
88
- if (!this.surface.initialized) {
89
- this.surface.initialize(grid, seed);
90
- }
91
-
92
- super.initialize(grid, seed);
60
+ get children() {
61
+ return [this.surface];
93
62
  }
94
63
 
95
64
  /**
@@ -104,19 +73,26 @@ export class CellFilterCurvature extends CellFilter {
104
73
 
105
74
  const surface = this.surface;
106
75
 
76
+ assert.equal(scratch_locked, false, 're-entrant curvature computation, surface filter graph contains another curvature filter');
77
+
78
+ scratch_locked = true;
79
+
107
80
  //compute normals up, down, left, right
108
- computeNormal(grid, yneg, surface, x, y - 1);
109
- computeNormal(grid, xneg, surface, x - 1, y);
110
- computeNormal(grid, xpos, surface, x + 1, y);
111
- computeNormal(grid, ypos, surface, x, y + 1);
81
+ computeFilterSurfaceNormal(yneg, surface, grid, x, y - 1);
82
+ computeFilterSurfaceNormal(xneg, surface, grid, x - 1, y);
83
+ computeFilterSurfaceNormal(xpos, surface, grid, x + 1, y);
84
+ computeFilterSurfaceNormal(ypos, surface, grid, x, y + 1);
112
85
 
113
86
 
114
- // compute curvature value
87
+ // compute curvature value; with the heightfield normal convention a convex
88
+ // surface (dome) yields positive curvature, a concave one (bowl) negative
115
89
  const cross_xneg_xpos_y = xneg[2] * xpos[0] - xneg[0] * xpos[2];
116
90
  const cross_yneg_ypos_x = yneg[1] * ypos[2] - yneg[2] * ypos[1];
117
91
 
118
92
  const curvature = (cross_xneg_xpos_y - cross_yneg_ypos_x);
119
93
 
94
+ scratch_locked = false;
95
+
120
96
  return curvature;
121
97
  }
122
98
  }
@@ -33,7 +33,6 @@ export class CellFilterFXAA extends CellFilter {
33
33
  * @type {number}
34
34
  */
35
35
  console_edge_sharpness: number;
36
- initialize(grid: any, seed: any): void;
37
36
  execute(grid: any, x: any, y: any, rotation: any): number;
38
37
  }
39
38
  import { CellFilter } from "../../CellFilter.js";
@@ -1 +1 @@
1
- {"version":3,"file":"CellFilterFXAA.d.ts","sourceRoot":"","sources":["../../../../../../src/generation/filtering/numeric/complex/CellFilterFXAA.js"],"names":[],"mappings":"AAQA;;GAEG;AACH;IAiCI;;;;OAIG;IACH,oBAHW,UAAU,GACR,cAAc,CAY1B;IA7CD;;;OAGG;IACH,QAFU,UAAU,CAEN;IAEd;;;;OAIG;IACH,gBAFU,MAAM,CAEM;IAEtB;;;;;OAKG;IACH,4BAFU,MAAM,CAEkB;IAElC;;;;;OAKG;IACH,wBAFU,MAAM,CAEW;IAoB3B,uCAMC;IAED,0DAwDC;CACJ;2BAxH0B,qBAAqB"}
1
+ {"version":3,"file":"CellFilterFXAA.d.ts","sourceRoot":"","sources":["../../../../../../src/generation/filtering/numeric/complex/CellFilterFXAA.js"],"names":[],"mappings":"AAQA;;GAEG;AACH;IAiCI;;;;OAIG;IACH,oBAHW,UAAU,GACR,cAAc,CAY1B;IA7CD;;;OAGG;IACH,QAFU,UAAU,CAEN;IAEd;;;;OAIG;IACH,gBAFU,MAAM,CAEM;IAEtB;;;;;OAKG;IACH,4BAFU,MAAM,CAEkB;IAElC;;;;;OAKG;IACH,wBAFU,MAAM,CAEW;IAwB3B,0DAwDC;CACJ;2BApH0B,qBAAqB"}
@@ -59,12 +59,8 @@ export class CellFilterFXAA extends CellFilter {
59
59
  return r;
60
60
  }
61
61
 
62
- initialize(grid, seed) {
63
- super.initialize(grid, seed);
64
-
65
- if (!this.source.initialized) {
66
- this.source.initialize(grid, seed);
67
- }
62
+ get children() {
63
+ return [this.source];
68
64
  }
69
65
 
70
66
  execute(grid, x, y, rotation) {
@@ -1 +1 @@
1
- {"version":3,"file":"CellFilterGaussianBlur.d.ts","sourceRoot":"","sources":["../../../../../../src/generation/filtering/numeric/complex/CellFilterGaussianBlur.js"],"names":[],"mappings":"AAMA;IA+DI;;;;;;;OAOG;IACH,oBANW,UAAU,KACV,MAAM,KACN,MAAM,YACN,MAAM,GACJ,sBAAsB,CAkBlC;IAtFD,kBAAc;IACd,kBAAc;IAEd,gBAAa;IACb,gBAAa;IAEb;;;OAGG;IACH,QAFU,UAAU,CAEN;IAEd,eAAW;IACX,eAAW;IAEX;;;;OAIG;IACH,iBAA+B;IAE/B;;;;OAIG;IACH,wBAAoB;IAEpB;;;;OAIG;IACH,wBAAoB;IAEpB,uCAuBC;IA6BD,0DA4CC;CACJ;2BAxI0B,qBAAqB"}
1
+ {"version":3,"file":"CellFilterGaussianBlur.d.ts","sourceRoot":"","sources":["../../../../../../src/generation/filtering/numeric/complex/CellFilterGaussianBlur.js"],"names":[],"mappings":"AAMA;IA2DI;;;;;;;OAOG;IACH,oBANW,UAAU,KACV,MAAM,KACN,MAAM,YACN,MAAM,GACJ,sBAAsB,CAmBlC;IAnFD,kBAAc;IACd,kBAAc;IAEd,gBAAa;IACb,gBAAa;IAEb;;;OAGG;IACH,QAFU,UAAU,CAEN;IAEd,eAAW;IACX,eAAW;IAEX;;;;OAIG;IACH,iBAA+B;IAE/B;;;;OAIG;IACH,wBAAoB;IAEpB;;;;OAIG;IACH,wBAAoB;IAMpB,uCAeC;IA8BD,0DA4CC;CACJ;2BArI0B,qBAAqB"}
@@ -41,14 +41,12 @@ export class CellFilterGaussianBlur extends CellFilter {
41
41
  */
42
42
  __local_v_scale = 0;
43
43
 
44
- initialize(grid, seed) {
45
- if (this.initialized) {
46
- return;
47
- }
44
+ get children() {
45
+ return [this.source];
46
+ }
48
47
 
49
- if (!this.source.initialized) {
50
- this.source.initialize(grid, seed);
51
- }
48
+ initialize(grid, seed) {
49
+ super.initialize(grid, seed);
52
50
 
53
51
  assert.isNonNegativeInteger(this.samples_x, 'samples_x');
54
52
  assert.isNonNegativeInteger(this.samples_y, 'samples_y');
@@ -62,8 +60,6 @@ export class CellFilterGaussianBlur extends CellFilter {
62
60
  // precompute scaling for the sampling(execute) stage
63
61
  this.__local_u_scale = this.size_x / (this.samples_x - 1);
64
62
  this.__local_v_scale = this.size_y / (this.samples_y - 1);
65
-
66
- super.initialize(grid, seed);
67
63
  }
68
64
 
69
65
 
@@ -86,9 +82,10 @@ export class CellFilterGaussianBlur extends CellFilter {
86
82
  r.size_x = x;
87
83
  r.size_y = y;
88
84
 
89
- // sigma should scale with radius
90
- r.sigma_x = x * 3;
91
- r.sigma_y = y * 3;
85
+ // sigma is in kernel-index units; the kernel spans ±(samples-1)/2 indices
86
+ // and should cover ±3 sigma of the gaussian
87
+ r.sigma_x = (r.samples_x - 1) / 6;
88
+ r.sigma_y = (r.samples_y - 1) / 6;
92
89
 
93
90
  return r;
94
91
  }
@@ -1 +1 @@
1
- {"version":3,"file":"CellFilterSimplexNoise.d.ts","sourceRoot":"","sources":["../../../../../../src/generation/filtering/numeric/complex/CellFilterSimplexNoise.js"],"names":[],"mappings":"AAQA;IA2BI;;;;;;;;OAQG;IACH,wBAPW,MAAM,SACN,MAAM,SAGN,MAAM,gBAFN,MAAM,eACN,MAAM,GAEJ,UAAU,CAyCtB;IAED;;;;;;OAMG;IACH,qBALW,MAAM,WACN,MAAM,SACN,MAAM,GACJ,sBAAsB,CAalC;IA7FG;;;OAGG;IACH,cAAa;IAEb;;;OAGG;IACH,eAAyB;IAEzB,gBAAY;IACZ,gBAAY;IAEZ,oBAAgB;IAChB,oBAAgB;IAEhB;;;;OAIG;IACH,eAAW;IAwEf,uCAMC;IAED,0DAKC;CACJ;2BArH0B,qBAAqB"}
1
+ {"version":3,"file":"CellFilterSimplexNoise.d.ts","sourceRoot":"","sources":["../../../../../../src/generation/filtering/numeric/complex/CellFilterSimplexNoise.js"],"names":[],"mappings":"AAQA;IA2BI;;;;;;;;OAQG;IACH,wBAPW,MAAM,SACN,MAAM,SAGN,MAAM,gBAFN,MAAM,eACN,MAAM,GAEJ,UAAU,CA0CtB;IAED;;;;;;OAMG;IACH,qBALW,MAAM,WACN,MAAM,SACN,MAAM,GACJ,sBAAsB,CAalC;IA9FG;;;OAGG;IACH,cAAa;IAEb;;;OAGG;IACH,eAAyB;IAEzB,gBAAY;IACZ,gBAAY;IAEZ,oBAAgB;IAChB,oBAAgB;IAEhB;;;;OAIG;IACH,eAAW;IAyEf,uCAMC;IAED,0DAKC;CACJ;2BAtH0B,qBAAqB"}
@@ -53,7 +53,8 @@ export class CellFilterSimplexNoise extends CellFilter {
53
53
  const G = Math.pow(2, -persistence);
54
54
 
55
55
  for (let i = 0; i < octaves; i++) {
56
- const noise = CellFilterSimplexNoise.from(scale * frequency, scale * frequency, s);
56
+ // scale is a wavelength, successive octaves are higher frequency = shorter wavelength
57
+ const noise = CellFilterSimplexNoise.from(scale / frequency, scale / frequency, s);
57
58
 
58
59
  if (r === undefined) {
59
60
  r = noise;
@@ -13,7 +13,6 @@ export class CellFilterSobel extends CellFilter {
13
13
  * @type {CellFilter}
14
14
  */
15
15
  source: CellFilter;
16
- initialize(grid: any, seed: any): void;
17
16
  execute(grid: any, x: any, y: any, rotation: any): number;
18
17
  }
19
18
  import { CellFilter } from "../../CellFilter.js";
@@ -1 +1 @@
1
- {"version":3,"file":"CellFilterSobel.d.ts","sourceRoot":"","sources":["../../../../../../src/generation/filtering/numeric/complex/CellFilterSobel.js"],"names":[],"mappings":"AAGA;;GAEG;AACH;IAiBI;;;;OAIG;IACH,oBAHW,UAAU,GACR,eAAe,CAU3B;IA5BD;;;OAGG;IACH,QAFU,UAAU,CAEN;IAEd,uCAMC;IAkBD,0DAuBC;CACJ;2BA9D0B,qBAAqB"}
1
+ {"version":3,"file":"CellFilterSobel.d.ts","sourceRoot":"","sources":["../../../../../../src/generation/filtering/numeric/complex/CellFilterSobel.js"],"names":[],"mappings":"AAGA;;GAEG;AACH;IAaI;;;;OAIG;IACH,oBAHW,UAAU,GACR,eAAe,CAU3B;IAxBD;;;OAGG;IACH,QAFU,UAAU,CAEN;IAsBd,0DAuBC;CACJ;2BA1D0B,qBAAqB"}
@@ -12,12 +12,8 @@ export class CellFilterSobel extends CellFilter {
12
12
  */
13
13
  source = null;
14
14
 
15
- initialize(grid, seed) {
16
- super.initialize(grid, seed);
17
-
18
- if (!this.source.initialized) {
19
- this.source.initialize(grid, seed);
20
- }
15
+ get children() {
16
+ return [this.source];
21
17
  }
22
18
 
23
19
 
@@ -1,9 +1,10 @@
1
1
  export class CellFilterInverseLerp extends CellFilterOperationTertiary {
2
2
  /**
3
- *
4
- * @param {CellFilter} a
5
- * @param {CellFilter} b
6
- * @param {CellFilter} f Interpolation factor, expected value between 0 and 1, 0 would lead to filter A being used, and 1 to filter B being used, values between 0 and 1 produce a proportional mix
3
+ * Computes where `value` sits between `a` and `b`: result is 0 when value equals A, 1 when value equals B,
4
+ * proportional in between (the inverse of lerp)
5
+ * @param {CellFilter} a Lower edge
6
+ * @param {CellFilter} b Upper edge
7
+ * @param {CellFilter} f Value to be mapped into the [a,b] range
7
8
  * @returns {CellFilterInverseLerp}
8
9
  */
9
10
  static from(a: CellFilter, b: CellFilter, f: CellFilter): CellFilterInverseLerp;
@@ -1 +1 @@
1
- {"version":3,"file":"CellFilterInverseLerp.d.ts","sourceRoot":"","sources":["../../../../../../src/generation/filtering/numeric/math/CellFilterInverseLerp.js"],"names":[],"mappings":"AAIA;IAEI;;;;;;OAMG;IACH,0DAFa,qBAAqB,CAoBjC;IAED,8CAEC;CACJ;4CAnC2C,2CAA2C"}
1
+ {"version":3,"file":"CellFilterInverseLerp.d.ts","sourceRoot":"","sources":["../../../../../../src/generation/filtering/numeric/math/CellFilterInverseLerp.js"],"names":[],"mappings":"AAIA;IAEI;;;;;;;OAOG;IACH,0DAFa,qBAAqB,CAoBjC;IAED,8CAEC;CACJ;4CApC2C,2CAA2C"}
@@ -5,10 +5,11 @@ import { assert } from "../../../../core/assert.js";
5
5
  export class CellFilterInverseLerp extends CellFilterOperationTertiary {
6
6
 
7
7
  /**
8
- *
9
- * @param {CellFilter} a
10
- * @param {CellFilter} b
11
- * @param {CellFilter} f Interpolation factor, expected value between 0 and 1, 0 would lead to filter A being used, and 1 to filter B being used, values between 0 and 1 produce a proportional mix
8
+ * Computes where `value` sits between `a` and `b`: result is 0 when value equals A, 1 when value equals B,
9
+ * proportional in between (the inverse of lerp)
10
+ * @param {CellFilter} a Lower edge
11
+ * @param {CellFilter} b Upper edge
12
+ * @param {CellFilter} f Value to be mapped into the [a,b] range
12
13
  * @returns {CellFilterInverseLerp}
13
14
  */
14
15
  static from(a, b, f) {
@@ -0,0 +1,17 @@
1
+ /**
2
+ * Compute the surface normal of a filter treated as a heightfield over the grid plane.
3
+ *
4
+ * Convention: the filter value is height along z, the normal's z component points "up"
5
+ * (towards increasing height); for a surface rising along +x the normal tilts towards -x.
6
+ *
7
+ * NOTE: `result` is only written after all filter sampling is done, so the same scratch
8
+ * array may safely be threaded through nested filter graphs.
9
+ *
10
+ * @param {number[]} result normalized x,y,z
11
+ * @param {CellFilter} filter
12
+ * @param {GridData} grid
13
+ * @param {number} x
14
+ * @param {number} y
15
+ */
16
+ export function computeFilterSurfaceNormal(result: number[], filter: CellFilter, grid: GridData, x: number, y: number): void;
17
+ //# sourceMappingURL=computeFilterSurfaceNormal.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"computeFilterSurfaceNormal.d.ts","sourceRoot":"","sources":["../../../../../../src/generation/filtering/numeric/process/computeFilterSurfaceNormal.js"],"names":[],"mappings":"AAMA;;;;;;;;;;;;;;GAcG;AACH,mDANW,MAAM,EAAE,yCAGR,MAAM,KACN,MAAM,QAsBhB"}
@@ -0,0 +1,42 @@
1
+ /**
2
+ * Distance from the reference point where support points are sampled to compute the derivative
3
+ * @type {number}
4
+ */
5
+ const DERIVATIVE_OFFSET = 1;
6
+
7
+ /**
8
+ * Compute the surface normal of a filter treated as a heightfield over the grid plane.
9
+ *
10
+ * Convention: the filter value is height along z, the normal's z component points "up"
11
+ * (towards increasing height); for a surface rising along +x the normal tilts towards -x.
12
+ *
13
+ * NOTE: `result` is only written after all filter sampling is done, so the same scratch
14
+ * array may safely be threaded through nested filter graphs.
15
+ *
16
+ * @param {number[]} result normalized x,y,z
17
+ * @param {CellFilter} filter
18
+ * @param {GridData} grid
19
+ * @param {number} x
20
+ * @param {number} y
21
+ */
22
+ export function computeFilterSurfaceNormal(result, filter, grid, x, y) {
23
+
24
+ //read surrounding points
25
+ const top = filter.execute(grid, x, y - DERIVATIVE_OFFSET, 0);
26
+
27
+ const left = filter.execute(grid, x - DERIVATIVE_OFFSET, y, 0);
28
+ const right = filter.execute(grid, x + DERIVATIVE_OFFSET, y, 0);
29
+
30
+ const bottom = filter.execute(grid, x, y + DERIVATIVE_OFFSET, 0);
31
+
32
+ // central differences over a span of 2 * DERIVATIVE_OFFSET
33
+ const dX = right - left;
34
+ const dY = bottom - top;
35
+
36
+ // normal of a heightfield is proportional to (-dh/dx, -dh/dy, 1)
37
+ const magnitude = Math.sqrt(dX * dX + dY * dY + 4);
38
+
39
+ result[0] = -dX / magnitude;
40
+ result[1] = -dY / magnitude;
41
+ result[2] = 2 / magnitude;
42
+ }
@@ -1 +1 @@
1
- {"version":3,"file":"AbstractCellFilterSampleGridLayer.d.ts","sourceRoot":"","sources":["../../../../../../src/generation/filtering/numeric/sampling/AbstractCellFilterSampleGridLayer.js"],"names":[],"mappings":"AAEA;IAGI;;;OAGG;IACH,SAFU,MAAM,CAED;IAEf;;;;OAIG;IACH,gBAAe;IAEf,kBAAc;IACd,kBAAc;IACd;;;;OAIG;IACH,kBAAiB;IAGjB,uCAUC;CAEJ;2BAxC0B,qBAAqB"}
1
+ {"version":3,"file":"AbstractCellFilterSampleGridLayer.d.ts","sourceRoot":"","sources":["../../../../../../src/generation/filtering/numeric/sampling/AbstractCellFilterSampleGridLayer.js"],"names":[],"mappings":"AAEA;IAGI;;;OAGG;IACH,SAFU,MAAM,CAED;IAEf;;;;OAIG;IACH,gBAAe;IAEf,kBAAc;IACd,kBAAc;IACd;;;;OAIG;IACH,kBAAiB;IAGjB,uCAgBC;CAEJ;2BA9C0B,qBAAqB"}