@woosh/meep-engine 2.110.13 → 2.110.15

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 (439) hide show
  1. package/package.json +4 -3
  2. package/src/engine/graphics/camera/CameraShake.d.ts +6 -6
  3. package/src/engine/graphics/camera/CameraShake.d.ts.map +1 -1
  4. package/src/engine/graphics/camera/CameraShake.js +13 -13
  5. package/src/engine/graphics/ecs/water2/shader/testWaterShader.js +4 -4
  6. package/editor/actions/concrete/ModifyPatchSampler2DAction.spec.js +0 -30
  7. package/src/core/IdPool.spec.js +0 -29
  8. package/src/core/UUID.spec.js +0 -8
  9. package/src/core/binary/32BitEncoder.spec.js +0 -11
  10. package/src/core/binary/Base64.spec.js +0 -14
  11. package/src/core/binary/BinaryBuffer.spec.js +0 -324
  12. package/src/core/binary/BitSet.spec.js +0 -468
  13. package/src/core/binary/EncodingBinaryBuffer.spec.js +0 -16
  14. package/src/core/binary/align_32.spec.js +0 -11
  15. package/src/core/binary/align_4.spec.js +0 -20
  16. package/src/core/binary/data_view/DataViewStructAccessor.spec.js +0 -20
  17. package/src/core/binary/de_interleave_2_bits.spec.js +0 -21
  18. package/src/core/binary/dec2hex.spec.js +0 -13
  19. package/src/core/binary/hex2dec.spec.js +0 -22
  20. package/src/core/binary/int32_to_binary_string.spec.js +0 -9
  21. package/src/core/binary/operations/bitCount.spec.js +0 -19
  22. package/src/core/binary/operations/ceilPowerOfTwo.spec.js +0 -17
  23. package/src/core/binary/reverse_bits_uint32.spec.js +0 -18
  24. package/src/core/binary/split_by_2.spec.js +0 -22
  25. package/src/core/binary/split_by_3.spec.js +0 -22
  26. package/src/core/binary/uint8_to_float.spec.js +0 -7
  27. package/src/core/bvh2/binary/2/BinaryUint32BVH.spec.js +0 -136
  28. package/src/core/bvh2/bvh3/BVH.spec.js +0 -361
  29. package/src/core/bvh2/bvh3/BvhClient.spec.js +0 -51
  30. package/src/core/bvh2/bvh3/ebvh_build_for_geometry_morton.spec.js +0 -60
  31. package/src/core/bvh2/bvh3/query/bvh_query_leaves_generic.spec.js +0 -22
  32. package/src/core/bvh2/bvh3/query/bvh_query_leaves_ray.spec.js +0 -64
  33. package/src/core/bvh2/bvh3/query/bvh_query_user_data_generic.spec.js +0 -29
  34. package/src/core/bvh2/bvh3/query/bvh_query_user_data_nearest_to_point.spec.js +0 -209
  35. package/src/core/bvh2/bvh3/query/compute_tight_near_far_clipping_planes.spec.js +0 -41
  36. package/src/core/cache/Cache.spec.js +0 -277
  37. package/src/core/cache/FrequencySketch.spec.js +0 -5
  38. package/src/core/cache/LoadingCache.spec.js +0 -120
  39. package/src/core/codegen/LineBuilder.spec.js +0 -41
  40. package/src/core/collection/CuckooFilter.spec.js +0 -111
  41. package/src/core/collection/RingBuffer.spec.js +0 -59
  42. package/src/core/collection/Stack.spec.js +0 -63
  43. package/src/core/collection/array/arrayPickBestElement.spec.js +0 -7
  44. package/src/core/collection/array/arraySetSortingDiff.spec.js +0 -74
  45. package/src/core/collection/array/array_contains_duplicates.spec.js +0 -14
  46. package/src/core/collection/array/array_copy.spec.js +0 -19
  47. package/src/core/collection/array/array_deduplicate.spec.js +0 -11
  48. package/src/core/collection/array/array_get_index_in_range.spec.js +0 -16
  49. package/src/core/collection/array/array_remove_first.spec.js +0 -39
  50. package/src/core/collection/array/array_shuffle.spec.js +0 -27
  51. package/src/core/collection/array/binarySearchHighIndex.spec.js +0 -51
  52. package/src/core/collection/array/isArrayEqual.spec.js +0 -25
  53. package/src/core/collection/array/typed/is_typed_array_equals.spec.js +0 -71
  54. package/src/core/collection/array/weightedRandomFromArray.spec.js +0 -22
  55. package/src/core/collection/heap/BinaryHeap.spec.js +0 -137
  56. package/src/core/collection/heap/Uint32Heap.spec.js +0 -172
  57. package/src/core/collection/list/List.spec.js +0 -438
  58. package/src/core/collection/list/ListForwarder.spec.js +0 -101
  59. package/src/core/collection/map/HashMap.spec.js +0 -291
  60. package/src/core/collection/queue/Deque.spec.js +0 -276
  61. package/src/core/collection/set/HashSet.spec.js +0 -39
  62. package/src/core/collection/set/compute_set_difference.spec.js +0 -45
  63. package/src/core/collection/set/compute_set_intersection.spec.js +0 -45
  64. package/src/core/collection/table/RowFirstTable.spec.js +0 -323
  65. package/src/core/collection/table/RowFirstTableSpec.spec.js +0 -49
  66. package/src/core/collection/table/bind/TableRecord.spec.js +0 -27
  67. package/src/core/color/Color.spec.js +0 -174
  68. package/src/core/color/YCbCr/YCbCr.spec.js +0 -16
  69. package/src/core/color/hex/hex2rgb.spec.js +0 -10
  70. package/src/core/color/hex/rgb2hex.spec.js +0 -13
  71. package/src/core/color/hsv/hsv2rgb.spec.js +0 -43
  72. package/src/core/color/kelvin/kelvin_to_rgb.spec.js +0 -61
  73. package/src/core/color/kelvin/rgb_to_kelvin.spec.js +0 -15
  74. package/src/core/color/oklab/Okhsv.spec.js +0 -17
  75. package/src/core/color/oklab/XYZ.spec.js +0 -17
  76. package/src/core/color/oklab/oklab_to_xyz.spec.js +0 -31
  77. package/src/core/color/oklab/xyz_to_oklab.spec.js +0 -31
  78. package/src/core/color/parse_color.spec.js +0 -18
  79. package/src/core/color/sRGB/sRGB.spec.js +0 -16
  80. package/src/core/color/xyz/XYZ.spec.js +0 -16
  81. package/src/core/events/signal/Signal.spec.js +0 -253
  82. package/src/core/events/signal/SignalBinding.spec.js +0 -58
  83. package/src/core/fsm/simple/SimpleStateMachine.spec.js +0 -107
  84. package/src/core/fsm/simple/SimpleStateMachineDescription.spec.js +0 -103
  85. package/src/core/function/extractFunctionBody.spec.js +0 -15
  86. package/src/core/geom/2d/Rectangle.spec.js +0 -62
  87. package/src/core/geom/2d/aabb/AABB2.spec.js +0 -153
  88. package/src/core/geom/2d/aabb/aabb2_compute_center_from_multiple.spec.js +0 -11
  89. package/src/core/geom/2d/aabb/aabb2_compute_overlap.spec.js +0 -56
  90. package/src/core/geom/2d/aabb/aabb2_contains.spec.js +0 -40
  91. package/src/core/geom/2d/aabb/aabb2_distance_to_point.spec.js +0 -17
  92. package/src/core/geom/2d/aabb/aabb2_intersects_ray.spec.js +0 -28
  93. package/src/core/geom/2d/aabb/aabb2_signed_distance_sqr_to_point.spec.js +0 -40
  94. package/src/core/geom/2d/bvh/BVH2D.spec.js +0 -359
  95. package/src/core/geom/2d/bvh/bvh2d_query_all_data_by_circle.spec.js +0 -89
  96. package/src/core/geom/2d/circle/circle_compute_circle_intersection.spec.js +0 -79
  97. package/src/core/geom/2d/compute_polygon_area_2d.spec.js +0 -10
  98. package/src/core/geom/2d/compute_triangle_area_2d.spec.js +0 -9
  99. package/src/core/geom/2d/convex-hull/convex_hull_jarvis_2d.spec.js +0 -33
  100. package/src/core/geom/2d/convex-hull/convex_hull_monotone_2d.spec.js +0 -33
  101. package/src/core/geom/2d/hash-grid/SpatialHashGrid.spec.js +0 -254
  102. package/src/core/geom/2d/hash-grid/shg_query_elements_circle.spec.js +0 -85
  103. package/src/core/geom/2d/hash-grid/shg_query_elements_line.spec.js +0 -102
  104. package/src/core/geom/2d/quad-tree/QuadTreeNode.spec.js +0 -235
  105. package/src/core/geom/2d/quad-tree/qt_match_data_by_circle.spec.js +0 -86
  106. package/src/core/geom/2d/quad-tree-binary/QuadTree.spec.js +0 -53
  107. package/src/core/geom/2d/r-tree/StaticR2Tree.spec.js +0 -62
  108. package/src/core/geom/2d/spline_bezier2_2d.spec.js +0 -16
  109. package/src/core/geom/2d/uv_map_circle_to_square.spec.js +0 -28
  110. package/src/core/geom/2d/uv_map_square_to_circle.spec.js +0 -30
  111. package/src/core/geom/3d/SurfacePoint3.spec.js +0 -116
  112. package/src/core/geom/3d/aabb/AABB3.spec.js +0 -257
  113. package/src/core/geom/3d/aabb/aabb3_array_intersects_point.spec.js +0 -48
  114. package/src/core/geom/3d/aabb/aabb3_build_corners.spec.js +0 -27
  115. package/src/core/geom/3d/aabb/aabb3_compute_distance_above_plane_max.spec.js +0 -8
  116. package/src/core/geom/3d/aabb/aabb3_compute_plane_side.spec.js +0 -25
  117. package/src/core/geom/3d/aabb/aabb3_corner_edge_mapping.spec.js +0 -39
  118. package/src/core/geom/3d/aabb/aabb3_edge_corner_mapping.spec.js +0 -32
  119. package/src/core/geom/3d/aabb/aabb3_expand_array.spec.js +0 -16
  120. package/src/core/geom/3d/aabb/aabb3_from_v3_array.spec.js +0 -32
  121. package/src/core/geom/3d/aabb/aabb3_intersects_aabb3.spec.js +0 -115
  122. package/src/core/geom/3d/aabb/aabb3_intersects_ray.spec.js +0 -161
  123. package/src/core/geom/3d/aabb/aabb3_matrix4_project.spec.js +0 -54
  124. package/src/core/geom/3d/aabb/aabb3_raycast.spec.js +0 -37
  125. package/src/core/geom/3d/aabb/aabb3_score_boxes_SAH.spec.js +0 -14
  126. package/src/core/geom/3d/cone/computeConePlaneSide.spec.js +0 -13
  127. package/src/core/geom/3d/cone/compute_bounding_cone_of_2_cones.spec.js +0 -95
  128. package/src/core/geom/3d/line/line3_compute_nearest_point_to_point.spec.js +0 -61
  129. package/src/core/geom/3d/mat4/MATRIX_4_IDENTITY.spec.js +0 -10
  130. package/src/core/geom/3d/mat4/m4_multiply.spec.js +0 -34
  131. package/src/core/geom/3d/mat4/m4_multiply_alphatensor.spec.js +0 -35
  132. package/src/core/geom/3d/morton/v3_morton_encode_transformed.spec.js +0 -20
  133. package/src/core/geom/3d/normal/hemioct/unit_hemioct.spec.js +0 -41
  134. package/src/core/geom/3d/normal/octahedron/encoding.spec.js +0 -54
  135. package/src/core/geom/3d/plane/plane3_projectPoint.spec.js +0 -54
  136. package/src/core/geom/3d/plane/plane3_slerp.spec.js +0 -209
  137. package/src/core/geom/3d/ray/ray3_array_compose.spec.js +0 -14
  138. package/src/core/geom/3d/shape/TransformedShape3D.spec.js +0 -55
  139. package/src/core/geom/3d/shape/UnitCubeShape3D.spec.js +0 -42
  140. package/src/core/geom/3d/sphere/harmonics/sh3_dering_optimize_positive.spec.js +0 -53
  141. package/src/core/geom/3d/sphere/harmonics/sh3_vector_accumulate.spec.js +0 -27
  142. package/src/core/geom/3d/sphere/sphere_intersects_point.spec.js +0 -134
  143. package/src/core/geom/3d/sphere/sphere_intersects_ray.spec.js +0 -60
  144. package/src/core/geom/3d/sphere/sphere_radius_sqr_from_v3_array_transformed.spec.js +0 -8
  145. package/src/core/geom/3d/tetrahedra/TetrahedralMesh.spec.js +0 -233
  146. package/src/core/geom/3d/tetrahedra/compute_bounding_simplex_3d.spec.js +0 -66
  147. package/src/core/geom/3d/tetrahedra/delaunay/compute_delaunay_tetrahedral_mesh.spec.js +0 -36
  148. package/src/core/geom/3d/tetrahedra/delaunay/tetrahedral_mesh_build_from_grid.spec.js +0 -61
  149. package/src/core/geom/3d/tetrahedra/delaunay/tetrahedral_mesh_compute_sub_determinant.spec.js +0 -30
  150. package/src/core/geom/3d/tetrahedra/tetrahedron_compute_signed_volume.spec.js +0 -24
  151. package/src/core/geom/3d/tetrahedra/tetrahedron_contains_point.spec.js +0 -66
  152. package/src/core/geom/3d/topology/simplify/collapseEdge.spec.js +0 -24
  153. package/src/core/geom/3d/topology/struct/TopoEdge.spec.js +0 -52
  154. package/src/core/geom/3d/topology/struct/TopoVertex.spec.js +0 -128
  155. package/src/core/geom/3d/topology/struct/binary/BinaryElementPool.spec.js +0 -36
  156. package/src/core/geom/3d/topology/struct/binary/BinaryTopology.spec.js +0 -16
  157. package/src/core/geom/3d/topology/struct/binary/io/bt_index_geometry_to_topology.spec.js +0 -84
  158. package/src/core/geom/3d/topology/struct/binary/query/bt_mesh_edge_has_vertex.spec.js +0 -15
  159. package/src/core/geom/3d/topology/struct/binary/query/bt_mesh_edge_other_vertex.spec.js +0 -16
  160. package/src/core/geom/3d/triangle/computeTriangleClosestPointToPointBarycentric.spec.js +0 -100
  161. package/src/core/geom/3d/triangle/computeTriangleRayIntersection.spec.js +0 -25
  162. package/src/core/geom/3d/triangle/computeTriangleRayIntersectionBarycentric.spec.js +0 -26
  163. package/src/core/geom/3d/v3_compute_triangle_normal.spec.js +0 -46
  164. package/src/core/geom/ConicRay.spec.js +0 -24
  165. package/src/core/geom/Quaternion.spec.js +0 -429
  166. package/src/core/geom/Vector1.spec.js +0 -74
  167. package/src/core/geom/Vector2.spec.js +0 -295
  168. package/src/core/geom/Vector3.spec.js +0 -285
  169. package/src/core/geom/Vector4.spec.js +0 -11
  170. package/src/core/geom/normalize_angle_rad.spec.js +0 -45
  171. package/src/core/geom/packing/computeBoundingSphereOfSpheres.spec.js +0 -24
  172. package/src/core/geom/packing/max-rect/MaxRectanglesPacker.spec.js +0 -60
  173. package/src/core/geom/packing/miniball/Miniball.spec.js +0 -35
  174. package/src/core/geom/packing/miniball/Subspan.spec.js +0 -51
  175. package/src/core/geom/random/randomPointOnBox.spec.js +0 -57
  176. package/src/core/geom/vec/vector_normalize.spec.js +0 -15
  177. package/src/core/geom/vec3/v3_angle_cos_between.spec.js +0 -124
  178. package/src/core/geom/vec3/v3_displace_in_direction.spec.js +0 -80
  179. package/src/core/geom/vec3/v3_distance_above_plane.spec.js +0 -40
  180. package/src/core/graph/Edge.spec.js +0 -85
  181. package/src/core/graph/SquareMatrix.spec.js +0 -102
  182. package/src/core/graph/coloring/colorizeGraphGreedy.spec.js +0 -26
  183. package/src/core/graph/convert_graph_to_dot_string.spec.js +0 -28
  184. package/src/core/graph/eigen/matrix_eigenvalues_in_place.spec.js +0 -57
  185. package/src/core/graph/graph_k_means_cluster.spec.js +0 -23
  186. package/src/core/graph/mn_graph_coarsen.spec.js +0 -45
  187. package/src/core/graph/v2/Graph.spec.js +0 -364
  188. package/src/core/json/resolvePath.spec.js +0 -14
  189. package/src/core/lang/reactive/compileReactiveExpression.spec.js +0 -169
  190. package/src/core/math/bessel_j0.spec.js +0 -43
  191. package/src/core/math/clamp.spec.js +0 -15
  192. package/src/core/math/computeGreatestCommonDivisor.spec.js +0 -9
  193. package/src/core/math/computeIsoscelesTriangleApexAngle.spec.js +0 -6
  194. package/src/core/math/computeWholeDivisorLow.spec.js +0 -9
  195. package/src/core/math/copysign.spec.js +0 -13
  196. package/src/core/math/epsilonEquals.spec.js +0 -17
  197. package/src/core/math/factorial.spec.js +0 -9
  198. package/src/core/math/fract.spec.js +0 -11
  199. package/src/core/math/hash/computeHashFloatArray.spec.js +0 -11
  200. package/src/core/math/hash/computeObjectHash.spec.js +0 -42
  201. package/src/core/math/hash/murmur3_32.spec.js +0 -8
  202. package/src/core/math/hash/squirrel3.spec.js +0 -16
  203. package/src/core/math/iabs.spec.js +0 -9
  204. package/src/core/math/interval/NumericInterval.spec.js +0 -89
  205. package/src/core/math/interval/isValueBetween.spec.js +0 -11
  206. package/src/core/math/interval/isValueBetweenInclusive.spec.js +0 -16
  207. package/src/core/math/interval/overlap1D.spec.js +0 -10
  208. package/src/core/math/inverseLerp.spec.js +0 -13
  209. package/src/core/math/isPowerOfTwo.spec.js +0 -9
  210. package/src/core/math/isqrt.spec.js +0 -9
  211. package/src/core/math/lerp.spec.js +0 -15
  212. package/src/core/math/linalg/solve_linear_system.spec.js +0 -70
  213. package/src/core/math/max.spec.js +0 -25
  214. package/src/core/math/max2.spec.js +0 -13
  215. package/src/core/math/max3.spec.js +0 -29
  216. package/src/core/math/min2.spec.js +0 -37
  217. package/src/core/math/min3.spec.js +0 -29
  218. package/src/core/math/newton_solver_1d.spec.js +0 -9
  219. package/src/core/math/nextOdd.spec.js +0 -9
  220. package/src/core/math/noise/create_simplex_noise_2d.spec.js +0 -21
  221. package/src/core/math/noise/sdnoise.spec.js +0 -87
  222. package/src/core/math/physics/irradiance/interpolate_irradiance_linear.spec.js +0 -20
  223. package/src/core/math/physics/irradiance/interpolate_irradiance_lograrithmic.spec.js +0 -18
  224. package/src/core/math/physics/irradiance/interpolate_irradiance_smith.spec.js +0 -20
  225. package/src/core/math/pingpong.spec.js +0 -11
  226. package/src/core/math/random/MersenneTwister.spec.js +0 -19
  227. package/src/core/math/random/randomFloatBetween.spec.js +0 -9
  228. package/src/core/math/random/randomGaussian.spec.js +0 -9
  229. package/src/core/math/random/randomIntegerBetween.spec.js +0 -8
  230. package/src/core/math/random/roundFair.spec.js +0 -12
  231. package/src/core/math/random/seededRandomMersenneTwister.spec.js +0 -10
  232. package/src/core/math/random/seededRandom_Mulberry32.spec.js +0 -19
  233. package/src/core/math/remap.spec.js +0 -15
  234. package/src/core/math/sign.spec.js +0 -13
  235. package/src/core/math/smoothStep.spec.js +0 -16
  236. package/src/core/math/smootherStep.spec.js +0 -16
  237. package/src/core/math/solveQuadratic.spec.js +0 -18
  238. package/src/core/math/spline/cubicCurve.spec.js +0 -13
  239. package/src/core/math/spline/makeCubicCurve.spec.js +0 -9
  240. package/src/core/math/spline/spline_bezier2.spec.js +0 -13
  241. package/src/core/math/spline/spline_bezier3_bounds.spec.js +0 -37
  242. package/src/core/math/spline/spline_hermite3.spec.js +0 -18
  243. package/src/core/math/spline/spline_hermite3_bounds.spec.js +0 -37
  244. package/src/core/math/statistics/computeSampleSize_Cochran.spec.js +0 -12
  245. package/src/core/math/statistics/computeStatisticalMean.spec.js +0 -9
  246. package/src/core/math/statistics/computeStatisticalPartialMedian.spec.js +0 -13
  247. package/src/core/math/statistics/computeStatisticalPercentile.spec.js +0 -11
  248. package/src/core/math/statistics/computeStatisticalVariance.spec.js +0 -10
  249. package/src/core/math/statistics/halton_sequence.spec.js +0 -40
  250. package/src/core/math/statistics/radical_inverse_VdC_base_2.spec.js +0 -9
  251. package/src/core/math/statistics/softmax.spec.js +0 -9
  252. package/src/core/model/BooleanVector3.spec.js +0 -51
  253. package/src/core/model/BoundedValue.spec.js +0 -17
  254. package/src/core/model/ModuleRegistry.spec.js +0 -31
  255. package/src/core/model/ObservedBoolean.spec.js +0 -81
  256. package/src/core/model/ObservedInteger.spec.js +0 -51
  257. package/src/core/model/node-graph/Connection.spec.js +0 -33
  258. package/src/core/model/node-graph/NodeGraph.spec.js +0 -107
  259. package/src/core/model/node-graph/node/NodeDescription.spec.js +0 -81
  260. package/src/core/model/node-graph/node/NodeInstance.spec.js +0 -82
  261. package/src/core/model/node-graph/node/NodeInstancePortReference.spec.js +0 -109
  262. package/src/core/model/node-graph/node/NodeRegistry.spec.js +0 -123
  263. package/src/core/model/node-graph/node/Port.spec.js +0 -102
  264. package/src/core/model/node-graph/type/DataType.spec.js +0 -47
  265. package/src/core/model/node-graph/type/ParametricDataType.spec.js +0 -63
  266. package/src/core/model/node-graph/visual/PortVisualData.spec.js +0 -16
  267. package/src/core/model/object/ObjectPoolFactory.spec.js +0 -54
  268. package/src/core/model/object/objectDeepEquals.spec.js +0 -54
  269. package/src/core/model/object/write_property.spec.js +0 -26
  270. package/src/core/model/reactive/evaluation/MultiPredicateEvaluator.spec.js +0 -158
  271. package/src/core/model/reactive/js/compileReactiveToJS.spec.js +0 -14
  272. package/src/core/model/reactive/model/logic/ReactiveAnd.spec.js +0 -51
  273. package/src/core/model/reactive/model/logic/ReactiveOr.spec.js +0 -53
  274. package/src/core/model/reactive/model/terminal/ReactiveReference.spec.js +0 -26
  275. package/src/core/model/reactive/trigger/BlackboardTrigger.spec.js +0 -24
  276. package/src/core/model/reactive/trigger/ReactiveTrigger.spec.js +0 -5
  277. package/src/core/model/stat/LinearModifier.spec.js +0 -96
  278. package/src/core/model/stat/Stat.spec.js +0 -111
  279. package/src/core/parser/simple/readHexToken.spec.js +0 -21
  280. package/src/core/parser/simple/readIdentifierToken.spec.js +0 -32
  281. package/src/core/parser/simple/readNumberToken.spec.js +0 -17
  282. package/src/core/parser/simple/readReferenceToken.spec.js +0 -18
  283. package/src/core/parser/simple/readStringToken.spec.js +0 -57
  284. package/src/core/parser/simple/readUnsignedIntegerToken.spec.js +0 -6
  285. package/src/core/path/computeFileExtension.spec.js +0 -13
  286. package/src/core/path/computePathBase.spec.js +0 -13
  287. package/src/core/path/computePathDirectory.spec.js +0 -8
  288. package/src/core/primitives/array/computeStridedIntegerArrayHash.spec.js +0 -28
  289. package/src/core/primitives/numbers/computeHashFloat.spec.js +0 -14
  290. package/src/core/primitives/numbers/number_compare_ascending.spec.js +0 -9
  291. package/src/core/primitives/numbers/number_compare_descending.spec.js +0 -9
  292. package/src/core/primitives/numbers/number_format_by_thousands.spec.js +0 -12
  293. package/src/core/primitives/numbers/number_pretty_print.spec.js +0 -19
  294. package/src/core/primitives/strings/compareStrings.spec.js +0 -12
  295. package/src/core/primitives/strings/computeStringHash.spec.js +0 -20
  296. package/src/core/primitives/strings/insert_after.spec.js +0 -16
  297. package/src/core/primitives/strings/insert_before.spec.js +0 -16
  298. package/src/core/primitives/strings/string_capitalize.spec.js +0 -13
  299. package/src/core/primitives/strings/string_compute_common_prefix.spec.js +0 -23
  300. package/src/core/primitives/strings/string_format_camel_to_kebab.spec.js +0 -8
  301. package/src/core/primitives/strings/string_jaro_winkler.spec.js +0 -39
  302. package/src/core/primitives/strings/string_strip_trailing.spec.js +0 -27
  303. package/src/core/process/PromiseWatcher.spec.js +0 -69
  304. package/src/core/process/executor/ConcurrentExecutor.spec.js +0 -135
  305. package/src/core/process/task/util/actionTask.spec.js +0 -14
  306. package/src/core/process/task/util/countTask.spec.js +0 -18
  307. package/src/core/process/undo/ActionProcessor.spec.js +0 -64
  308. package/src/engine/Clock.spec.js +0 -26
  309. package/src/engine/Engine.spec.js +0 -15
  310. package/src/engine/achievements/Achievement.spec.js +0 -21
  311. package/src/engine/animation/curve/AnimationCurve.spec.js +0 -248
  312. package/src/engine/animation/curve/Keyframe.spec.js +0 -42
  313. package/src/engine/animation/curve/animation_curve_optimize.spec.js +0 -50
  314. package/src/engine/animation/curve/compression/downsample_float_array_curve_by_error.spec.js +0 -47
  315. package/src/engine/animation/curve/compression/sample_animation_curve_to_float_array.spec.js +0 -29
  316. package/src/engine/animation/keyed2/AnimationTrackPlayback.spec.js +0 -94
  317. package/src/engine/asset/AssetDescription.spec.js +0 -27
  318. package/src/engine/asset/AssetManager.spec.js +0 -50
  319. package/src/engine/asset/loaders/image/png/PNG.spec.js +0 -5
  320. package/src/engine/asset/loaders/image/png/PNGReader.spec.js +0 -5
  321. package/src/engine/asset/loaders/image/png/crc.spec.js +0 -15
  322. package/src/engine/control/ControlContext.spec.js +0 -81
  323. package/src/engine/ecs/Entity.spec.js +0 -188
  324. package/src/engine/ecs/EntityBlueprint.spec.js +0 -52
  325. package/src/engine/ecs/EntityComponentDataset.spec.js +0 -895
  326. package/src/engine/ecs/EntityManager.spec.js +0 -210
  327. package/src/engine/ecs/EntityObserver.spec.js +0 -184
  328. package/src/engine/ecs/animation/Animation.spec.js +0 -22
  329. package/src/engine/ecs/animation/AnimationClip.spec.js +0 -5
  330. package/src/engine/ecs/components/Tag.spec.js +0 -47
  331. package/src/engine/ecs/dynamic_actions/rules/DynamicRuleDescriptionTable.spec.js +0 -126
  332. package/src/engine/ecs/fow/FogOfWar.spec.js +0 -13
  333. package/src/engine/ecs/guid/UUID.spec.js +0 -100
  334. package/src/engine/ecs/guid/UUIDSerializationAdapter.spec.js +0 -21
  335. package/src/engine/ecs/parent/EntityNode.spec.js +0 -104
  336. package/src/engine/ecs/renderable/Renderable.spec.js +0 -10
  337. package/src/engine/ecs/storage/binary/BinarySerializationRegistry.spec.js +0 -139
  338. package/src/engine/ecs/storage/binary/collection/BinaryCollectionSerialization.spec.js +0 -259
  339. package/src/engine/ecs/storage/binary/object/BinaryObjectSerializationAdapter.spec.js +0 -59
  340. package/src/engine/ecs/storage/binary/object/BinaryObjectSerializationAdapter2.spec.js +0 -123
  341. package/src/engine/ecs/terrain/ecs/Terrain.spec.js +0 -5
  342. package/src/engine/ecs/terrain/ecs/cling/ClingToTerrainSystem.spec.js +0 -38
  343. package/src/engine/ecs/terrain/overlay/TerrainOverlay.spec.js +0 -6
  344. package/src/engine/ecs/terrain/tiles/TerrainTile.spec.js +0 -25
  345. package/src/engine/ecs/tooltip/TooltipComponent.spec.js +0 -47
  346. package/src/engine/ecs/transform/Transform.spec.js +0 -310
  347. package/src/engine/ecs/transform/TransformSerializationAdapter.spec.js +0 -28
  348. package/src/engine/ecs/transform-attachment/TransformAttachment.spec.js +0 -103
  349. package/src/engine/graphics/ecs/animation/animator/graph/AnimationGraph.spec.js +0 -5
  350. package/src/engine/graphics/ecs/animation/animator/graph/definition/AnimationGraphDefinition.spec.js +0 -5
  351. package/src/engine/graphics/ecs/camera/topdown/TopDownCameraController.spec.js +0 -94
  352. package/src/engine/graphics/ecs/decal/v2/Decal.spec.js +0 -5
  353. package/src/engine/graphics/ecs/mesh-v2/ShadedGeometry.spec.js +0 -19
  354. package/src/engine/graphics/ecs/mesh-v2/aggregate/SGMesh.spec.js +0 -5
  355. package/src/engine/graphics/ecs/mesh-v2/render/adapters/SGCacheKey.spec.js +0 -79
  356. package/src/engine/graphics/ecs/path/tube/TubePathStyle.spec.js +0 -5
  357. package/src/engine/graphics/ecs/path/tube/build/build_geometry_catmullrom.spec.js +0 -32
  358. package/src/engine/graphics/geometry/MikkT/MikkTSpace.spec.js +0 -28
  359. package/src/engine/graphics/geometry/bvh/buffered/bvh32_from_unindexed_geometry.spec.js +0 -22
  360. package/src/engine/graphics/particles/particular/engine/MovingBoundingBox.spec.js +0 -70
  361. package/src/engine/graphics/particles/particular/engine/emitter/ParticleEmitter.spec.js +0 -47
  362. package/src/engine/graphics/particles/particular/engine/emitter/ParticleLayer.spec.js +0 -100
  363. package/src/engine/graphics/particles/particular/engine/emitter/ParticlePool.spec.js +0 -225
  364. package/src/engine/graphics/particles/particular/engine/parameter/ParameterLookupTable.spec.js +0 -215
  365. package/src/engine/graphics/particles/particular/engine/parameter/ParameterSet.spec.js +0 -75
  366. package/src/engine/graphics/particles/particular/group/ParticleGroup.spec.js +0 -270
  367. package/src/engine/graphics/render/buffer/slot/parameter/ProgramValueSlotParameter.spec.js +0 -21
  368. package/src/engine/graphics/render/forward_plus/LightManager.spec.js +0 -94
  369. package/src/engine/graphics/render/forward_plus/cluster/write_cluster_planes.spec.js +0 -79
  370. package/src/engine/graphics/render/visibility/IncrementalDeltaSet.spec.js +0 -102
  371. package/src/engine/graphics/texture/atlas/CachingTextureAtlas.spec.js +0 -78
  372. package/src/engine/graphics/texture/atlas/TextureAtlas.spec.js +0 -319
  373. package/src/engine/graphics/texture/sampler/HarmonicDiffusionGrid.spec.js +0 -99
  374. package/src/engine/graphics/texture/sampler/Sampler2D.spec.js +0 -224
  375. package/src/engine/graphics/texture/sampler/copy_Sampler2D_channel_data.spec.js +0 -90
  376. package/src/engine/graphics/texture/sampler/distance/computeSignedDistanceField_NaiveFlood.spec.js +0 -183
  377. package/src/engine/graphics/texture/sampler/distance/computeUnsignedDistanceField.spec.js +0 -183
  378. package/src/engine/graphics/texture/sampler/resize/sampler2d_scale.spec.js +0 -73
  379. package/src/engine/graphics/texture/sampler/resize/sampler2d_scale_down_lanczos.spec.js +0 -31
  380. package/src/engine/graphics/texture/sampler/resize/sampler2d_scale_down_linear.spec.js +0 -44
  381. package/src/engine/graphics/texture/sampler/resize/sampler2d_scale_down_mipmap.spec.js +0 -13
  382. package/src/engine/graphics/texture/sampler/resize/sampler2d_scale_up_linear.spec.js +0 -14
  383. package/src/engine/graphics/texture/sampler/sampler2d_channel_compute_max.spec.js +0 -40
  384. package/src/engine/graphics/texture/sampler/sampler2d_channel_compute_min_indices.spec.js +0 -15
  385. package/src/engine/graphics/texture/sampler/sampler2d_copy_with_margins.spec.js +0 -31
  386. package/src/engine/graphics/texture/sampler/sampler2d_to_data_url.spec.js +0 -10
  387. package/src/engine/graphics/texture/sampler/sampler2d_to_uint8_RGBA.spec.js +0 -52
  388. package/src/engine/graphics/texture/sampler/serialization/TextureBinaryBufferSerializer.spec.js +0 -38
  389. package/src/engine/graphics/three/expand_aabb_by_transformed_three_object.spec.js +0 -108
  390. package/src/engine/graphics/trail/x/RibbonX.spec.js +0 -5
  391. package/src/engine/grid/obstacle/GridObstacle.spec.js +0 -175
  392. package/src/engine/input/devices/InputDeviceSwitch.spec.js +0 -5
  393. package/src/engine/input/devices/KeyboardDevice.spec.js +0 -12
  394. package/src/engine/input/devices/PointerDevice.spec.js +0 -12
  395. package/src/engine/intelligence/behavior/Behavior.spec.js +0 -15
  396. package/src/engine/intelligence/behavior/SelectorBehavior.spec.js +0 -18
  397. package/src/engine/intelligence/behavior/behavior_to_dot.spec.js +0 -25
  398. package/src/engine/intelligence/behavior/composite/ParallelBehavior.spec.js +0 -166
  399. package/src/engine/intelligence/behavior/composite/SequenceBehavior.spec.js +0 -17
  400. package/src/engine/intelligence/behavior/decorator/RepeatBehavior.spec.js +0 -32
  401. package/src/engine/intelligence/behavior/ecs/BehaviorSystem.spec.js +0 -75
  402. package/src/engine/intelligence/behavior/util/ConditionBehavior.spec.js +0 -24
  403. package/src/engine/intelligence/blackboard/Blackboard.spec.js +0 -111
  404. package/src/engine/intelligence/blackboard/BlackboardSerializationAdapter.spec.js +0 -30
  405. package/src/engine/intelligence/blackboard/make_blackboard_proxy.spec.js +0 -23
  406. package/src/engine/intelligence/mcts/MonteCarlo.spec.js +0 -244
  407. package/src/engine/intelligence/mcts/StateNode.spec.js +0 -49
  408. package/src/engine/intelligence/optimization/RandomOptimizer.spec.js +0 -57
  409. package/src/engine/intelligence/resource/ResourceAllocationSolver.spec.js +0 -104
  410. package/src/engine/intelligence/resource/StrategicResourceAllocator.spec.js +0 -46
  411. package/src/engine/knowledge/database/StaticKnowledgeDataTable.spec.js +0 -26
  412. package/src/engine/knowledge/database/StaticKnowledgeDatabase.spec.js +0 -23
  413. package/src/engine/navigation/ecs/components/Path.spec.js +0 -195
  414. package/src/engine/navigation/ecs/path_following/PathFollower.spec.js +0 -27
  415. package/src/engine/navigation/grid/find_path_on_grid_astar.spec.js +0 -87
  416. package/src/engine/notify/NotificationLog.spec.js +0 -17
  417. package/src/engine/options/Option.spec.js +0 -69
  418. package/src/engine/options/OptionGroup.spec.js +0 -61
  419. package/src/engine/physics/gjk/expanding_polytope_algorithm.spec.js +0 -46
  420. package/src/engine/physics/inverse_kinematics/fabrik/fabrik3d_solve_primitive.spec.js +0 -43
  421. package/src/engine/plugin/EnginePlugin.spec.js +0 -5
  422. package/src/engine/reference/v2/Reference.spec.js +0 -44
  423. package/src/engine/scene/Scene.spec.js +0 -20
  424. package/src/engine/scene/SceneManager.spec.js +0 -131
  425. package/src/engine/sound/ecs/emitter/SoundEmitterSerializationAdapter.spec.js +0 -49
  426. package/src/engine/ui/tiles2d/TileGrid.spec.js +0 -20
  427. package/src/engine/ui/tiles2d/computeTileGridMove.spec.js +0 -54
  428. package/src/generation/automata/CaveGeneratorCellularAutomata.spec.js +0 -12
  429. package/src/generation/filtering/numeric/complex/CellFilterAngleToNormal.spec.js +0 -30
  430. package/src/generation/filtering/numeric/complex/CellFilterGaussianBlur.spec.js +0 -17
  431. package/src/generation/filtering/numeric/process/computeCellFilterGradient.spec.js +0 -288
  432. package/src/generation/grid/GridData.spec.js +0 -46
  433. package/src/generation/markers/actions/probability/MarkerNodeActionSelectWeighted.spec.js +0 -116
  434. package/src/generation/markers/transform/MarkerNodeTransformerYRotateByFilterGradient.spec.js +0 -106
  435. package/src/generation/placement/action/GridCellActionPlaceTags.spec.js +0 -21
  436. package/src/generation/rules/CellMatcherLayerBitMaskTest.spec.js +0 -22
  437. package/src/generation/rules/cell/GridPatternMatcher.spec.js +0 -285
  438. package/src/generation/theme/ThemeEngine.spec.js +0 -7
  439. package/src/view/tooltip/gml/TooltipParser.spec.js +0 -142
@@ -1,27 +0,0 @@
1
- import { sh3_vector_accumulate } from "./sh3_vector_accumulate.js";
2
-
3
- test("basics", () => {
4
- const out = [
5
- 1, 2,
6
- 3,4, 5,6,7,8,
7
- 9,10, 11,12, 13,14, 15,16, 17,18
8
- ];
9
- const basis = [
10
- 2,
11
- 3, 5, 7,
12
- 11, 13, 17, 19, 23
13
- ];
14
-
15
- sh3_vector_accumulate(
16
- out, 0,
17
- basis, 0,
18
- [-3, 5], 0,
19
- 2
20
- );
21
-
22
- expect(out).toEqual([
23
- -5, 12,
24
- -6, 19, -10, 31, -14, 43,
25
- -24, 65, -28, 77, -38, 99, -42, 111, -52, 133
26
- ]);
27
- });
@@ -1,134 +0,0 @@
1
- import { sphere_intersects_point } from "./sphere_intersects_point.js";
2
-
3
- test("zero volume sphere", () => {
4
-
5
- expect(sphere_intersects_point(
6
- 0, 0, 0, 0,
7
- 0, 0, 0
8
- )).toBe(false)
9
-
10
- expect(sphere_intersects_point(
11
- 0, 0, 0, 0,
12
- -1, 0, 0
13
- )).toBe(false)
14
-
15
- expect(sphere_intersects_point(
16
- 0, 0, 0, 0,
17
- 1, 0, 0
18
- )).toBe(false)
19
-
20
- expect(sphere_intersects_point(
21
- 0, 0, 0, 0,
22
- 0, -1, 0
23
- )).toBe(false)
24
-
25
- expect(sphere_intersects_point(
26
- 0, 0, 0, 0,
27
- 0, 1, 0
28
- )).toBe(false)
29
-
30
- expect(sphere_intersects_point(
31
- 0, 0, 0, 0,
32
- 0, 0, -1
33
- )).toBe(false)
34
-
35
- expect(sphere_intersects_point(
36
- 0, 0, 0, 0,
37
- 0, 0, 1
38
- )).toBe(false)
39
-
40
- });
41
-
42
- test("out of bounds, centered on origin", () => {
43
-
44
- // X
45
- expect(sphere_intersects_point(
46
- 0, 0, 0, 1,
47
- -2, 0, 0
48
- )).toBe(false)
49
-
50
- expect(sphere_intersects_point(
51
- 0, 0, 0, 1,
52
- 2, 0, 0
53
- )).toBe(false)
54
-
55
-
56
- // Y
57
- expect(sphere_intersects_point(
58
- 0, 0, 0, 1,
59
- 0, -2, 0
60
- )).toBe(false)
61
-
62
- expect(sphere_intersects_point(
63
- 0, 0, 0, 1,
64
- 0, 2, 0
65
- )).toBe(false)
66
-
67
- // Z
68
- expect(sphere_intersects_point(
69
- 0, 0, 0, 1,
70
- 0, 0, -2
71
- )).toBe(false)
72
-
73
- expect(sphere_intersects_point(
74
- 0, 0, 0, 1,
75
- 0, 0, 2
76
- )).toBe(false)
77
-
78
- });
79
-
80
- test("out of bounds with offset origin", () => {
81
-
82
- expect(sphere_intersects_point(
83
- 3, -5, 7, 1,
84
- 1, -5, 7
85
- )).toBe(false)
86
-
87
- expect(sphere_intersects_point(
88
- 3, -5, 7, 1,
89
- 5, -5, 7
90
- )).toBe(false)
91
-
92
- });
93
-
94
- test("in bounds", () => {
95
-
96
- expect(sphere_intersects_point(
97
- 0, 0, 0, 2,
98
- 0, 0, 0
99
- )).toBe(true)
100
-
101
- // X
102
- expect(sphere_intersects_point(
103
- 0, 0, 0, 2,
104
- -1, 0, 0
105
- )).toBe(true)
106
-
107
- expect(sphere_intersects_point(
108
- 5, 5, 5, 2,
109
- 4, 5, 5
110
- )).toBe(true)
111
-
112
- // Y
113
- expect(sphere_intersects_point(
114
- 0, 0, 0, 2,
115
- 0, -1, 0
116
- )).toBe(true)
117
-
118
- expect(sphere_intersects_point(
119
- 5, 5, 5, 2,
120
- 5, 4, 5
121
- )).toBe(true)
122
-
123
- // Z
124
- expect(sphere_intersects_point(
125
- 0, 0, 0, 2,
126
- 0, 0, -1
127
- )).toBe(true)
128
-
129
- expect(sphere_intersects_point(
130
- 5, 5, 5, 2,
131
- 5, 5, 4
132
- )).toBe(true)
133
-
134
- });
@@ -1,60 +0,0 @@
1
- import { sphere_intersects_ray } from "./sphere_intersects_ray.js";
2
-
3
- test("ray from -X to +X intersects sphere", () => {
4
- expect(sphere_intersects_ray(
5
- 0, 0, 0, 1,
6
- -2, 0, 0,
7
- 1, 0, 0
8
- )).toBe(true);
9
- });
10
-
11
- test("ray from +X to -X intersects sphere", () => {
12
- expect(sphere_intersects_ray(
13
- 0, 0, 0, 1,
14
- 2, 0, 0,
15
- -1, 0, 0
16
- )).toBe(true);
17
- });
18
-
19
- test("ray from -Y to +Y intersects sphere", () => {
20
- expect(sphere_intersects_ray(
21
- 0, 0, 0, 1,
22
- 0, -2, 0,
23
- 0, 1, 0
24
- )).toBe(true);
25
- });
26
-
27
- test("ray from +Y to -Y intersects sphere", () => {
28
- expect(sphere_intersects_ray(
29
- 0, 0, 0, 1,
30
- 0, 2, 0,
31
- 0, -1, 0
32
- )).toBe(true);
33
- });
34
-
35
- test("ray from -Z to +Z intersects sphere", () => {
36
- expect(sphere_intersects_ray(
37
- 0, 0, 0, 1,
38
- 0, 0, -2,
39
- 0, 0, 1
40
- )).toBe(true);
41
- });
42
-
43
- test("ray from +Z to -Z intersects sphere", () => {
44
- expect(sphere_intersects_ray(
45
- 0, 0, 0, 1,
46
- 0, 0, 2,
47
- 0, 0, -1
48
- )).toBe(true);
49
- });
50
-
51
-
52
- // negative cases
53
-
54
- test("ray from -X to -X", () => {
55
- expect(sphere_intersects_ray(
56
- 0, 0, 0, 1,
57
- -2, 0, 0,
58
- -1, 0, 0
59
- )).toBe(false);
60
- });
@@ -1,8 +0,0 @@
1
- import { MATRIX_4_IDENTITY } from "../mat4/MATRIX_4_IDENTITY.js";
2
- import { sphere_radius_sqr_from_v3_array_transformed } from "./sphere_radius_sqr_from_v3_array_transformed.js";
3
-
4
- test("base case", () => {
5
- expect(sphere_radius_sqr_from_v3_array_transformed([0, 0, 0], 3, MATRIX_4_IDENTITY)).toBe(0);
6
- expect(sphere_radius_sqr_from_v3_array_transformed([1, 0, 0], 3, MATRIX_4_IDENTITY)).toBe(1);
7
- expect(sphere_radius_sqr_from_v3_array_transformed([-1, 0, 0], 3, MATRIX_4_IDENTITY)).toBe(1);
8
- });
@@ -1,233 +0,0 @@
1
- import { jest } from "@jest/globals";
2
- import { TetrahedralMesh } from "./TetrahedralMesh.js";
3
-
4
- test("constructor does not throw", () => {
5
- expect(() => new TetrahedralMesh(1)).not.toThrow();
6
- });
7
-
8
- test("capacity set in constructor is respected", () => {
9
- const mesh = new TetrahedralMesh(7);
10
-
11
- expect(mesh.getCapacity()).toBe(7);
12
- });
13
-
14
- test("attempting to set capacity below what's used will throw", () => {
15
- const mesh = new TetrahedralMesh(1);
16
-
17
- mesh.allocate();
18
- mesh.allocate();
19
-
20
- expect(() => mesh.setCapacity(1)).toThrow();
21
- });
22
-
23
- test("set/get capacity consistence", () => {
24
- const mesh = new TetrahedralMesh(2);
25
-
26
- mesh.setCapacity(1);
27
-
28
- expect(mesh.getCapacity()).toBe(1);
29
-
30
- mesh.setCapacity(1); // idempotency check
31
-
32
- expect(mesh.getCapacity()).toBe(1);
33
-
34
- mesh.setCapacity(2);
35
-
36
- expect(mesh.getCapacity()).toBe(2);
37
- });
38
-
39
-
40
- test("set/get neighbour consistency", () => {
41
- const mesh = new TetrahedralMesh(7);
42
-
43
- const tet = mesh.allocate();
44
-
45
- mesh.setNeighbour(tet, 0, 7);
46
- mesh.setNeighbour(tet, 1, 3);
47
- mesh.setNeighbour(tet, 2, 11);
48
- mesh.setNeighbour(tet, 3, 13);
49
-
50
- //
51
- expect(mesh.getNeighbour(tet, 0)).toBe(7);
52
- expect(mesh.getNeighbour(tet, 1)).toBe(3);
53
- expect(mesh.getNeighbour(tet, 2)).toBe(11);
54
- expect(mesh.getNeighbour(tet, 3)).toBe(13);
55
- });
56
-
57
- test("set/get vertex index consistency", () => {
58
- const mesh = new TetrahedralMesh(7);
59
- const tet = mesh.allocate();
60
-
61
- mesh.setVertexIndex(tet, 0, 3);
62
- mesh.setVertexIndex(tet, 1, 7);
63
- mesh.setVertexIndex(tet, 2, 11);
64
- mesh.setVertexIndex(tet, 3, 13);
65
-
66
- //
67
- expect(mesh.getVertexIndex(tet, 0)).toBe(3);
68
- expect(mesh.getVertexIndex(tet, 1)).toBe(7);
69
- expect(mesh.getVertexIndex(tet, 2)).toBe(11);
70
- expect(mesh.getVertexIndex(tet, 3)).toBe(13);
71
- });
72
-
73
- test("allocation within capacity doesn't resize capacity", () => {
74
- const mesh = new TetrahedralMesh(1);
75
-
76
- expect(mesh.getCapacity()).toBe(1);
77
-
78
- mesh.allocate();
79
-
80
- expect(mesh.getCapacity()).toBe(1); // allocation fits in the capacity, so no growth is expected
81
- });
82
-
83
- test("allocation beyond capacity does not destroy existing data", () => {
84
- const mesh = new TetrahedralMesh(1);
85
-
86
- const t0 = mesh.allocate();
87
-
88
- expect(mesh.getCapacity()).toBe(1);
89
-
90
- for (let i = 0; i < 4; i++) {
91
- mesh.setNeighbour(t0, i, 1);
92
- mesh.setVertexIndex(t0, i, 3);
93
- }
94
-
95
- mesh.allocate(); // allocation over capacity
96
-
97
- expect(mesh.getCapacity()).toBeGreaterThan(1);
98
-
99
- for (let i = 0; i < 4; i++) {
100
- expect(mesh.getNeighbour(t0, i)).toBe(1);
101
- expect(mesh.getVertexIndex(t0, i)).toBe(3);
102
- }
103
-
104
- });
105
-
106
- test("allocation increases size", () => {
107
- const mesh = new TetrahedralMesh(1);
108
-
109
- expect(mesh.size()).toBe(0);
110
-
111
- mesh.allocate();
112
-
113
- expect(mesh.size()).toBe(1);
114
- });
115
-
116
- test("remove method reduces size", () => {
117
- const mesh = new TetrahedralMesh(1);
118
-
119
- const tet = mesh.allocate();
120
-
121
- expect(mesh.size()).toBe(1);
122
-
123
- mesh.delete(tet);
124
-
125
- expect(mesh.size()).toBe(0);
126
- });
127
-
128
-
129
- test("forEach visits all allocated tets", () => {
130
- const mesh = new TetrahedralMesh();
131
-
132
- const t0 = mesh.allocate();
133
- const t1 = mesh.allocate();
134
-
135
- const mock = jest.fn();
136
-
137
- mesh.forEach(mock);
138
-
139
- expect(mock).toHaveBeenCalledTimes(2);
140
- expect(mock).toHaveBeenCalledWith(t0, mesh);
141
- expect(mock).toHaveBeenCalledWith(t1, mesh);
142
- });
143
-
144
- test("'exists' method", () => {
145
- const mesh = new TetrahedralMesh();
146
-
147
- expect(mesh.exists(0)).toBe(false);
148
-
149
- const tet = mesh.allocate();
150
-
151
- expect(mesh.exists(tet)).toBe(true);
152
- expect(mesh.exists(tet + 1)).toBe(false);
153
-
154
- mesh.delete(tet);
155
-
156
- expect(mesh.exists(tet)).toBe(false);
157
- expect(mesh.exists(tet + 1)).toBe(false);
158
- });
159
-
160
-
161
- test("after calling 'removeTetrasConnectedToPoints' matching points are no logner indexed by live tetrahedrons", () => {
162
-
163
-
164
- const tetrahedra = new TetrahedralMesh();
165
-
166
- /*
167
- * This "magic" mesh is a result of tetrahedral mesh generator with following input: 0, 0, 0, 10, 0, 0, 10, 0, 10, 0, 0, 10, 0, 10, 0,
168
- * The mesh was generated on 27/10/2022
169
- * It's a very small example with 21 total tets that was failing this test
170
- *
171
- */
172
- tetrahedra.deserialize_base64('AAAAARUAAQAAAAAAAAAFAAAABgAAAAsAAAAUAAAAHwAAADQAAAADAAAABwAAAAUAAAAIAAAA/////yoAAABAAAAALgAAAAAAAAAFAAAABgAAAAgAAAD/////HAAAACgAAAAAAAAAAgAAAAUAAAAHAAAABgAAAP////8TAAAAFQAAACwAAAACAAAABgAAAAcAAAAIAAAA/////zwAAAAwAAAADQAAAAIAAAABAAAABQAAAAYAAAABAAAADgAAACAAAAA4AAAABAAAAAEAAAAGAAAACAAAAB0AAAAyAAAASQAAACEAAAABAAAAAAAAAAYAAAAIAAAACQAAABgAAABIAAAAAgAAAAQAAAACAAAABgAAAAEAAAAWAAAAGwAAACUAAAAzAAAABAAAAAMAAAACAAAAAQAAADsAAAAiAAAAUwAAAEYAAAADAAAABQAAAAAAAAAIAAAACgAAAEwAAAAFAAAANQAAAAMAAAAHAAAAAgAAAAUAAAAPAAAAOgAAAAcAAABEAAAABAAAAAYAAAACAAAACAAAABIAAAA+AAAAGQAAACMAAAADAAAAAQAAAAAAAAAFAAAAAwAAACsAAAA5AAAAUAAAAAMAAAACAAAAAQAAAAUAAAAXAAAANgAAAC0AAAAkAAAABAAAAAIAAAAHAAAACAAAABEAAABCAAAAMQAAAEUAAAAEAAAABwAAAAMAAAAIAAAABgAAAE4AAAA9AAAARwAAAAQAAAADAAAABwAAAAIAAAAvAAAAPwAAACcAAABDAAAABAAAAAAAAAABAAAACAAAAB4AAAAaAAAATQAAAFEAAAAEAAAAAwAAAAAAAAAIAAAAKQAAAEoAAABBAAAAUgAAAAQAAAADAAAAAQAAAAAAAAA3AAAASwAAAE8AAAAmAAAA');
173
-
174
- tetrahedra.removeTetrasConnectedToPoints(5, 8);
175
-
176
- //The mesh should contain only 5 vertices
177
-
178
- tetrahedra.forEach((tet, mesh) => {
179
-
180
- for (let i = 0; i < 4; i++) {
181
- expect(mesh.getVertexIndex(tet, i)).toBeLessThan(5);
182
- }
183
-
184
- });
185
- });
186
-
187
- test('relocate operation copies tet data and updates back-links correctly', () => {
188
- const mesh = new TetrahedralMesh();
189
-
190
- const a = mesh.allocate();
191
- const b = mesh.allocate();
192
- const dest = mesh.allocate();
193
-
194
- mesh.setVertexIndex(a, 0, 3);
195
- mesh.setVertexIndex(a, 1, 7);
196
- mesh.setVertexIndex(a, 2, 11);
197
- mesh.setVertexIndex(a, 3, 13);
198
-
199
- mesh.setNeighbour(a, 0, b << 2);
200
- mesh.setNeighbour(b, 0, a << 2);
201
-
202
- mesh.relocate(a, dest);
203
-
204
- expect(mesh.getVertexIndex(dest, 0)).toBe(3);
205
- expect(mesh.getVertexIndex(dest, 1)).toBe(7);
206
- expect(mesh.getVertexIndex(dest, 2)).toBe(11);
207
- expect(mesh.getVertexIndex(dest, 3)).toBe(13);
208
-
209
- expect(mesh.getNeighbour(dest, 0)).toBe(b << 2);
210
-
211
- // check back-link
212
- expect(mesh.getNeighbour(b, 0)).toBe(dest << 2);
213
- });
214
-
215
- test('Compaction is non-destructive when moving resident data from the very end of the allocated region', () => {
216
- const mesh = new TetrahedralMesh();
217
-
218
- const a = mesh.allocate();
219
- const b = mesh.allocate();
220
-
221
- // force move "a" to free set
222
- mesh.delete(a);
223
-
224
- expect(mesh.exists(b)).toBe(true);
225
- expect(mesh.exists(a)).toBe(false);
226
-
227
- mesh.compact();
228
-
229
- expect(mesh.size()).toBe(1);
230
-
231
- expect(mesh.exists(0)).toBe(true);
232
- expect(mesh.exists(1)).toBe(false);
233
- });
@@ -1,66 +0,0 @@
1
- import { compute_bounding_simplex_3d } from "./compute_bounding_simplex_3d.js";
2
- import { v3_distance } from "../../vec3/v3_distance.js";
3
- import { orient3d_fast } from "../plane/orient3d_fast.js";
4
-
5
- test('one point', () => {
6
- const r = [];
7
- compute_bounding_simplex_3d(r, 0, [1, 2, 3], 1, 0);
8
-
9
- for (let i = 0; i < 4; i++) {
10
- const i3 = i * 3;
11
-
12
- expect(r[i3]).toBeCloseTo(1);
13
- expect(r[i3 + 1]).toBeCloseTo(2);
14
- expect(r[i3 + 2]).toBeCloseTo(3);
15
- }
16
- });
17
-
18
- test('planar containment, one point', () => {
19
- const r = [];
20
-
21
- compute_bounding_simplex_3d(r, 0, [0, 0, 0], 1, 1);
22
-
23
- r.push(0, 0, 0);
24
-
25
- expect(orient3d_fast(r, 2, 3, 1, 4)).toBeLessThan(0);
26
- expect(orient3d_fast(r, 0, 3, 2, 4)).toBeLessThan(0);
27
- expect(orient3d_fast(r, 0, 1, 3, 4)).toBeLessThan(0);
28
- expect(orient3d_fast(r, 2, 1, 0, 4)).toBeLessThan(0);
29
- });
30
-
31
- test('positive padding results in larger simplex', () => {
32
- const r_0 = [];
33
- const r_n = [];
34
- const r_p = [];
35
-
36
- const volume = [
37
- -100, 0, 0,
38
- 100, 0, 0,
39
- 0, -100, 0,
40
- 0, 100, 0,
41
- 0, 0, -100,
42
- 0, 0, 100,
43
- ];
44
-
45
- compute_bounding_simplex_3d(r_0, 0, volume, 6, 0);
46
- compute_bounding_simplex_3d(r_n, 0, volume, 6, -1);
47
- compute_bounding_simplex_3d(r_p, 0, volume, 6, 1);
48
-
49
- function compute_distance_sum(ref, points, point_count) {
50
- let r = 0;
51
- for (let i = 0; i < point_count; i++) {
52
- const i3 = i * 3;
53
-
54
- r += v3_distance(points[i3], points[i3 + 1], points[i3 + 2], ref[0], ref[1], ref[2]);
55
- }
56
-
57
- return r;
58
- }
59
-
60
- const d_0 = compute_distance_sum([0, 0, 0], r_0, 4);
61
- const d_n = compute_distance_sum([0, 0, 0], r_n, 4);
62
- const d_p = compute_distance_sum([0, 0, 0], r_p, 4);
63
-
64
- expect(d_0).toBeLessThan(d_p);
65
- expect(d_0).toBeGreaterThan(d_n);
66
- });
@@ -1,36 +0,0 @@
1
- /**
2
- * @jest-environment jsdom
3
- */
4
-
5
- import { TetrahedralMesh } from "../TetrahedralMesh.js";
6
- import { validate_tetrahedral_mesh } from "../validate_tetrahedral_mesh.js";
7
- import { compute_delaunay_tetrahedral_mesh } from "./compute_delaunay_tetrahedral_mesh.js";
8
-
9
- test('single point', () => {
10
- const mesh = new TetrahedralMesh();
11
-
12
- compute_delaunay_tetrahedral_mesh(mesh, [1, 2, 3], 1);
13
- });
14
-
15
- test('exactly 4 points', () => {
16
- const mesh = new TetrahedralMesh();
17
- const points = [
18
- -1, 0, 0,
19
- 1, 0, 0,
20
- 0.5, 1, 0,
21
- 0.5, 0, 1
22
- ];
23
- compute_delaunay_tetrahedral_mesh(mesh, points, 4);
24
-
25
-
26
- // do full validation
27
- const problems = [];
28
-
29
- const is_valid = validate_tetrahedral_mesh(mesh, points, (problem) => problems.push(problem));
30
-
31
- if (!is_valid) {
32
- console.error(problems.join('\n'));
33
- }
34
-
35
- expect(is_valid).toBe(true);
36
- });
@@ -1,61 +0,0 @@
1
- import { AABB3 } from "../../aabb/AABB3.js";
2
- import { compute_tetrahedron_volume } from "../compute_tetrahedron_volume.js";
3
- import { TetrahedralMesh } from "../TetrahedralMesh.js";
4
- import { validate_tetrahedral_mesh } from "../validate_tetrahedral_mesh.js";
5
- import { tetrahedral_mesh_build_from_grid } from "./tetrahedral_mesh_build_from_grid.js";
6
-
7
- test("Single cube", () => {
8
-
9
- const mesh = new TetrahedralMesh();
10
-
11
- /**
12
- *
13
- * @type {number[]}
14
- */
15
- const points = [];
16
-
17
- tetrahedral_mesh_build_from_grid(
18
- mesh,
19
- points,
20
- new AABB3(0, 0, 0, 1, 1, 1),
21
- 2, 2, 2
22
- );
23
-
24
- // number of points
25
- expect(points.length).toBe(8 * 3);
26
-
27
- expect(mesh.count).toBeGreaterThanOrEqual(5);
28
- expect(mesh.count).toBeLessThanOrEqual(6);
29
-
30
- // mesh should only reference created points
31
- const tetrahedrons = mesh.getLive();
32
-
33
- for (let i = 0; i < tetrahedrons.length; i++) {
34
- const tet_index = tetrahedrons[i];
35
-
36
- for (let vertex_index = 0; vertex_index < 4; vertex_index++) {
37
-
38
- const vert = mesh.getVertexIndex(tet_index, vertex_index);
39
-
40
- expect(vert).toBeGreaterThanOrEqual(0);
41
- expect(vert).toBeLessThan(8);
42
- }
43
-
44
- // tetrahedrons should have positive volume
45
- const volume = compute_tetrahedron_volume(mesh, points, tet_index);
46
-
47
- expect(volume).toBeGreaterThan(0);
48
- }
49
-
50
- // do full validation
51
- const problems = [];
52
-
53
- const is_valid = validate_tetrahedral_mesh(mesh, points, (problem) => problems.push(problem));
54
-
55
- if (!is_valid) {
56
- console.error(problems.join('\n'));
57
- }
58
-
59
- expect(is_valid).toBe(true);
60
-
61
- });
@@ -1,30 +0,0 @@
1
- import { TetrahedralMesh } from "../TetrahedralMesh.js";
2
- import { tetrahedral_mesh_compute_sub_determinant } from "./tetrahedral_mesh_compute_sub_determinant.js";
3
-
4
- test("sanity test", () => {
5
- const mesh = new TetrahedralMesh(1);
6
-
7
- const tet = mesh.allocate();
8
-
9
- mesh.setVertexIndex(tet, 0, 0);
10
- mesh.setVertexIndex(tet, 1, 1);
11
- mesh.setVertexIndex(tet, 2, 2);
12
- mesh.setVertexIndex(tet, 3, 3);
13
-
14
- const result = [];
15
-
16
- const points = [
17
- 1, 2, 3,
18
- 4, 5, 6,
19
- 7, 8, 9,
20
- 10, 11, 12
21
- ];
22
-
23
- tetrahedral_mesh_compute_sub_determinant(result, 0, mesh, points, tet);
24
-
25
- for (let i = 0; i < 4; i++) {
26
- expect(typeof result[i]).toBe("number");
27
- expect(result[i]).not.toBeNaN();
28
- }
29
-
30
- });
@@ -1,24 +0,0 @@
1
- import { tetrahedron_compute_signed_volume } from "./tetrahedron_compute_signed_volume.js";
2
-
3
- test("0 volume", () => {
4
- expect(tetrahedron_compute_signed_volume([
5
- 0, 0, 0
6
- ], 0, 0, 0, 0)).toBe(0);
7
- });
8
-
9
- test("positive volume", () => {
10
-
11
- expect(tetrahedron_compute_signed_volume([
12
- 1, 0, 1,
13
- 1, 0, 0,
14
- 0, 0, 0,
15
- 1, 1, 1
16
- ], 1, 2, 3, 0)).toBeGreaterThan(0);
17
-
18
- expect(tetrahedron_compute_signed_volume([
19
- 0, 0, 0,
20
- 2, 0, 0,
21
- 0, 2, 0,
22
- 0, 0, 2
23
- ], 1, 2, 3, 0)).toBeGreaterThan(0);
24
- })