@bloomengine/engine 0.4.0 → 0.4.2

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 (527) hide show
  1. package/native/tvos/metal-patched/Cargo.toml +178 -0
  2. package/native/tvos/metal-patched/LICENSE-APACHE +201 -0
  3. package/native/tvos/metal-patched/LICENSE-MIT +25 -0
  4. package/native/tvos/metal-patched/src/acceleration_structure.rs +667 -0
  5. package/native/tvos/metal-patched/src/acceleration_structure_pass.rs +108 -0
  6. package/native/tvos/metal-patched/src/argument.rs +366 -0
  7. package/native/tvos/metal-patched/src/blitpass.rs +102 -0
  8. package/native/tvos/metal-patched/src/buffer.rs +71 -0
  9. package/native/tvos/metal-patched/src/capturedescriptor.rs +76 -0
  10. package/native/tvos/metal-patched/src/capturemanager.rs +113 -0
  11. package/native/tvos/metal-patched/src/commandbuffer.rs +192 -0
  12. package/native/tvos/metal-patched/src/commandqueue.rs +44 -0
  13. package/native/tvos/metal-patched/src/computepass.rs +107 -0
  14. package/native/tvos/metal-patched/src/constants.rs +152 -0
  15. package/native/tvos/metal-patched/src/counters.rs +119 -0
  16. package/native/tvos/metal-patched/src/depthstencil.rs +190 -0
  17. package/native/tvos/metal-patched/src/device.rs +2134 -0
  18. package/native/tvos/metal-patched/src/drawable.rs +39 -0
  19. package/native/tvos/metal-patched/src/encoder.rs +2041 -0
  20. package/native/tvos/metal-patched/src/heap.rs +281 -0
  21. package/native/tvos/metal-patched/src/indirect_encoder.rs +344 -0
  22. package/native/tvos/metal-patched/src/lib.rs +657 -0
  23. package/native/tvos/metal-patched/src/library.rs +902 -0
  24. package/native/tvos/metal-patched/src/mps.rs +575 -0
  25. package/native/tvos/metal-patched/src/pipeline/compute.rs +475 -0
  26. package/native/tvos/metal-patched/src/pipeline/mod.rs +71 -0
  27. package/native/tvos/metal-patched/src/pipeline/render.rs +762 -0
  28. package/native/tvos/metal-patched/src/renderpass.rs +443 -0
  29. package/native/tvos/metal-patched/src/resource.rs +182 -0
  30. package/native/tvos/metal-patched/src/sampler.rs +165 -0
  31. package/native/tvos/metal-patched/src/sync.rs +178 -0
  32. package/native/tvos/metal-patched/src/texture.rs +352 -0
  33. package/native/tvos/metal-patched/src/types.rs +90 -0
  34. package/native/tvos/metal-patched/src/vertexdescriptor.rs +250 -0
  35. package/package.json +8 -11
  36. package/native/third_party/JoltPhysics/Build/Android/PerformanceTest/build.gradle +0 -51
  37. package/native/third_party/JoltPhysics/Build/Android/PerformanceTest/src/main/AndroidManifest.xml +0 -20
  38. package/native/third_party/JoltPhysics/Build/Android/PerformanceTest/src/main/cpp/CMakeLists.txt +0 -20
  39. package/native/third_party/JoltPhysics/Build/Android/UnitTests/build.gradle +0 -51
  40. package/native/third_party/JoltPhysics/Build/Android/UnitTests/src/main/AndroidManifest.xml +0 -20
  41. package/native/third_party/JoltPhysics/Build/Android/UnitTests/src/main/cpp/CMakeLists.txt +0 -20
  42. package/native/third_party/JoltPhysics/Build/Android/build.gradle +0 -17
  43. package/native/third_party/JoltPhysics/Build/Android/gradle/wrapper/gradle-wrapper.jar +0 -0
  44. package/native/third_party/JoltPhysics/Build/Android/gradle/wrapper/gradle-wrapper.properties +0 -5
  45. package/native/third_party/JoltPhysics/Build/Android/gradle.properties +0 -21
  46. package/native/third_party/JoltPhysics/Build/Android/gradlew +0 -185
  47. package/native/third_party/JoltPhysics/Build/Android/gradlew.bat +0 -89
  48. package/native/third_party/JoltPhysics/Build/Android/settings.gradle +0 -10
  49. package/native/third_party/JoltPhysics/Build/CMakeLists.txt +0 -449
  50. package/native/third_party/JoltPhysics/Build/README.md +0 -250
  51. package/native/third_party/JoltPhysics/Build/cmake_linux_clang_gcc.sh +0 -28
  52. package/native/third_party/JoltPhysics/Build/cmake_linux_emscripten.sh +0 -19
  53. package/native/third_party/JoltPhysics/Build/cmake_linux_mingw.sh +0 -19
  54. package/native/third_party/JoltPhysics/Build/cmake_vs2022_cl.bat +0 -3
  55. package/native/third_party/JoltPhysics/Build/cmake_vs2022_cl_32bit.bat +0 -3
  56. package/native/third_party/JoltPhysics/Build/cmake_vs2022_cl_arm.bat +0 -3
  57. package/native/third_party/JoltPhysics/Build/cmake_vs2022_cl_arm_32bit.bat +0 -4
  58. package/native/third_party/JoltPhysics/Build/cmake_vs2022_cl_cross_platform_deterministic.bat +0 -3
  59. package/native/third_party/JoltPhysics/Build/cmake_vs2022_cl_double.bat +0 -3
  60. package/native/third_party/JoltPhysics/Build/cmake_vs2022_cl_no_object_stream.bat +0 -3
  61. package/native/third_party/JoltPhysics/Build/cmake_vs2022_clang.bat +0 -10
  62. package/native/third_party/JoltPhysics/Build/cmake_vs2022_clang_cross_platform_deterministic.bat +0 -10
  63. package/native/third_party/JoltPhysics/Build/cmake_vs2022_clang_double.bat +0 -10
  64. package/native/third_party/JoltPhysics/Build/cmake_vs2022_uwp.bat +0 -5
  65. package/native/third_party/JoltPhysics/Build/cmake_vs2022_uwp_arm.bat +0 -5
  66. package/native/third_party/JoltPhysics/Build/cmake_vs2026_cl.bat +0 -3
  67. package/native/third_party/JoltPhysics/Build/cmake_vs2026_cl_cross_platform_deterministic.bat +0 -3
  68. package/native/third_party/JoltPhysics/Build/cmake_vs2026_cl_double.bat +0 -3
  69. package/native/third_party/JoltPhysics/Build/cmake_vs2026_clang.bat +0 -10
  70. package/native/third_party/JoltPhysics/Build/cmake_vs2026_clang_cross_platform_deterministic.bat +0 -10
  71. package/native/third_party/JoltPhysics/Build/cmake_vs2026_clang_double.bat +0 -10
  72. package/native/third_party/JoltPhysics/Build/cmake_windows_mingw.sh +0 -19
  73. package/native/third_party/JoltPhysics/Build/cmake_xcode_ios.sh +0 -4
  74. package/native/third_party/JoltPhysics/Build/cmake_xcode_macos.sh +0 -4
  75. package/native/third_party/JoltPhysics/Build/iOS/JoltViewerInfo.plist +0 -34
  76. package/native/third_party/JoltPhysics/Build/iOS/SamplesInfo.plist +0 -34
  77. package/native/third_party/JoltPhysics/Build/iOS/UnitTestsInfo.plist +0 -34
  78. package/native/third_party/JoltPhysics/Build/macOS/icon.icns +0 -0
  79. package/native/third_party/JoltPhysics/Build/macos_install_vulkan_sdk.sh +0 -13
  80. package/native/third_party/JoltPhysics/Build/ubuntu24_install_vulkan_sdk.sh +0 -4
  81. package/native/third_party/JoltPhysics/Jolt/AABBTree/AABBTreeBuilder.cpp +0 -242
  82. package/native/third_party/JoltPhysics/Jolt/AABBTree/AABBTreeBuilder.h +0 -121
  83. package/native/third_party/JoltPhysics/Jolt/AABBTree/AABBTreeToBuffer.h +0 -296
  84. package/native/third_party/JoltPhysics/Jolt/AABBTree/NodeCodec/NodeCodecQuadTreeHalfFloat.h +0 -323
  85. package/native/third_party/JoltPhysics/Jolt/AABBTree/TriangleCodec/TriangleCodecIndexed8BitPackSOA4Flags.h +0 -555
  86. package/native/third_party/JoltPhysics/Jolt/ConfigurationString.h +0 -112
  87. package/native/third_party/JoltPhysics/Jolt/Core/ARMNeon.h +0 -94
  88. package/native/third_party/JoltPhysics/Jolt/Core/Array.h +0 -713
  89. package/native/third_party/JoltPhysics/Jolt/Core/Atomics.h +0 -44
  90. package/native/third_party/JoltPhysics/Jolt/Core/BinaryHeap.h +0 -96
  91. package/native/third_party/JoltPhysics/Jolt/Core/ByteBuffer.h +0 -74
  92. package/native/third_party/JoltPhysics/Jolt/Core/Color.cpp +0 -38
  93. package/native/third_party/JoltPhysics/Jolt/Core/Color.h +0 -98
  94. package/native/third_party/JoltPhysics/Jolt/Core/Core.h +0 -652
  95. package/native/third_party/JoltPhysics/Jolt/Core/FPControlWord.h +0 -143
  96. package/native/third_party/JoltPhysics/Jolt/Core/FPException.h +0 -96
  97. package/native/third_party/JoltPhysics/Jolt/Core/FPFlushDenormals.h +0 -43
  98. package/native/third_party/JoltPhysics/Jolt/Core/Factory.cpp +0 -92
  99. package/native/third_party/JoltPhysics/Jolt/Core/Factory.h +0 -54
  100. package/native/third_party/JoltPhysics/Jolt/Core/FixedSizeFreeList.h +0 -122
  101. package/native/third_party/JoltPhysics/Jolt/Core/FixedSizeFreeList.inl +0 -215
  102. package/native/third_party/JoltPhysics/Jolt/Core/HashCombine.h +0 -234
  103. package/native/third_party/JoltPhysics/Jolt/Core/HashTable.h +0 -876
  104. package/native/third_party/JoltPhysics/Jolt/Core/InsertionSort.h +0 -58
  105. package/native/third_party/JoltPhysics/Jolt/Core/IssueReporting.cpp +0 -27
  106. package/native/third_party/JoltPhysics/Jolt/Core/IssueReporting.h +0 -38
  107. package/native/third_party/JoltPhysics/Jolt/Core/JobSystem.h +0 -311
  108. package/native/third_party/JoltPhysics/Jolt/Core/JobSystem.inl +0 -56
  109. package/native/third_party/JoltPhysics/Jolt/Core/JobSystemSingleThreaded.cpp +0 -65
  110. package/native/third_party/JoltPhysics/Jolt/Core/JobSystemSingleThreaded.h +0 -62
  111. package/native/third_party/JoltPhysics/Jolt/Core/JobSystemThreadPool.cpp +0 -364
  112. package/native/third_party/JoltPhysics/Jolt/Core/JobSystemThreadPool.h +0 -101
  113. package/native/third_party/JoltPhysics/Jolt/Core/JobSystemWithBarrier.cpp +0 -230
  114. package/native/third_party/JoltPhysics/Jolt/Core/JobSystemWithBarrier.h +0 -85
  115. package/native/third_party/JoltPhysics/Jolt/Core/LinearCurve.cpp +0 -51
  116. package/native/third_party/JoltPhysics/Jolt/Core/LinearCurve.h +0 -67
  117. package/native/third_party/JoltPhysics/Jolt/Core/LockFreeHashMap.h +0 -182
  118. package/native/third_party/JoltPhysics/Jolt/Core/LockFreeHashMap.inl +0 -351
  119. package/native/third_party/JoltPhysics/Jolt/Core/Memory.cpp +0 -85
  120. package/native/third_party/JoltPhysics/Jolt/Core/Memory.h +0 -85
  121. package/native/third_party/JoltPhysics/Jolt/Core/Mutex.h +0 -223
  122. package/native/third_party/JoltPhysics/Jolt/Core/MutexArray.h +0 -98
  123. package/native/third_party/JoltPhysics/Jolt/Core/NonCopyable.h +0 -18
  124. package/native/third_party/JoltPhysics/Jolt/Core/Profiler.cpp +0 -677
  125. package/native/third_party/JoltPhysics/Jolt/Core/Profiler.h +0 -301
  126. package/native/third_party/JoltPhysics/Jolt/Core/Profiler.inl +0 -90
  127. package/native/third_party/JoltPhysics/Jolt/Core/QuickSort.h +0 -137
  128. package/native/third_party/JoltPhysics/Jolt/Core/RTTI.cpp +0 -149
  129. package/native/third_party/JoltPhysics/Jolt/Core/RTTI.h +0 -436
  130. package/native/third_party/JoltPhysics/Jolt/Core/Reference.h +0 -244
  131. package/native/third_party/JoltPhysics/Jolt/Core/Result.h +0 -174
  132. package/native/third_party/JoltPhysics/Jolt/Core/STLAlignedAllocator.h +0 -72
  133. package/native/third_party/JoltPhysics/Jolt/Core/STLAllocator.h +0 -127
  134. package/native/third_party/JoltPhysics/Jolt/Core/STLLocalAllocator.h +0 -170
  135. package/native/third_party/JoltPhysics/Jolt/Core/STLTempAllocator.h +0 -80
  136. package/native/third_party/JoltPhysics/Jolt/Core/ScopeExit.h +0 -49
  137. package/native/third_party/JoltPhysics/Jolt/Core/Semaphore.cpp +0 -135
  138. package/native/third_party/JoltPhysics/Jolt/Core/Semaphore.h +0 -68
  139. package/native/third_party/JoltPhysics/Jolt/Core/StaticArray.h +0 -329
  140. package/native/third_party/JoltPhysics/Jolt/Core/StreamIn.h +0 -120
  141. package/native/third_party/JoltPhysics/Jolt/Core/StreamOut.h +0 -97
  142. package/native/third_party/JoltPhysics/Jolt/Core/StreamUtils.h +0 -168
  143. package/native/third_party/JoltPhysics/Jolt/Core/StreamWrapper.h +0 -53
  144. package/native/third_party/JoltPhysics/Jolt/Core/StridedPtr.h +0 -63
  145. package/native/third_party/JoltPhysics/Jolt/Core/StringTools.cpp +0 -101
  146. package/native/third_party/JoltPhysics/Jolt/Core/StringTools.h +0 -38
  147. package/native/third_party/JoltPhysics/Jolt/Core/TempAllocator.h +0 -209
  148. package/native/third_party/JoltPhysics/Jolt/Core/TickCounter.cpp +0 -37
  149. package/native/third_party/JoltPhysics/Jolt/Core/TickCounter.h +0 -58
  150. package/native/third_party/JoltPhysics/Jolt/Core/UnorderedMap.h +0 -80
  151. package/native/third_party/JoltPhysics/Jolt/Core/UnorderedSet.h +0 -32
  152. package/native/third_party/JoltPhysics/Jolt/Geometry/AABox.h +0 -313
  153. package/native/third_party/JoltPhysics/Jolt/Geometry/AABox4.h +0 -224
  154. package/native/third_party/JoltPhysics/Jolt/Geometry/ClipPoly.h +0 -200
  155. package/native/third_party/JoltPhysics/Jolt/Geometry/ClosestPoint.h +0 -498
  156. package/native/third_party/JoltPhysics/Jolt/Geometry/ConvexHullBuilder.cpp +0 -1467
  157. package/native/third_party/JoltPhysics/Jolt/Geometry/ConvexHullBuilder.h +0 -276
  158. package/native/third_party/JoltPhysics/Jolt/Geometry/ConvexHullBuilder2D.cpp +0 -335
  159. package/native/third_party/JoltPhysics/Jolt/Geometry/ConvexHullBuilder2D.h +0 -105
  160. package/native/third_party/JoltPhysics/Jolt/Geometry/ConvexSupport.h +0 -188
  161. package/native/third_party/JoltPhysics/Jolt/Geometry/EPAConvexHullBuilder.h +0 -845
  162. package/native/third_party/JoltPhysics/Jolt/Geometry/EPAPenetrationDepth.h +0 -557
  163. package/native/third_party/JoltPhysics/Jolt/Geometry/Ellipse.h +0 -77
  164. package/native/third_party/JoltPhysics/Jolt/Geometry/GJKClosestPoint.h +0 -945
  165. package/native/third_party/JoltPhysics/Jolt/Geometry/IndexedTriangle.h +0 -130
  166. package/native/third_party/JoltPhysics/Jolt/Geometry/Indexify.cpp +0 -222
  167. package/native/third_party/JoltPhysics/Jolt/Geometry/Indexify.h +0 -19
  168. package/native/third_party/JoltPhysics/Jolt/Geometry/MortonCode.h +0 -40
  169. package/native/third_party/JoltPhysics/Jolt/Geometry/OrientedBox.cpp +0 -178
  170. package/native/third_party/JoltPhysics/Jolt/Geometry/OrientedBox.h +0 -39
  171. package/native/third_party/JoltPhysics/Jolt/Geometry/Plane.h +0 -104
  172. package/native/third_party/JoltPhysics/Jolt/Geometry/RayAABox.h +0 -241
  173. package/native/third_party/JoltPhysics/Jolt/Geometry/RayCapsule.h +0 -37
  174. package/native/third_party/JoltPhysics/Jolt/Geometry/RayCylinder.h +0 -101
  175. package/native/third_party/JoltPhysics/Jolt/Geometry/RaySphere.h +0 -96
  176. package/native/third_party/JoltPhysics/Jolt/Geometry/RayTriangle.h +0 -158
  177. package/native/third_party/JoltPhysics/Jolt/Geometry/Sphere.h +0 -72
  178. package/native/third_party/JoltPhysics/Jolt/Geometry/Triangle.h +0 -34
  179. package/native/third_party/JoltPhysics/Jolt/Jolt.cmake +0 -703
  180. package/native/third_party/JoltPhysics/Jolt/Jolt.h +0 -16
  181. package/native/third_party/JoltPhysics/Jolt/Jolt.natvis +0 -116
  182. package/native/third_party/JoltPhysics/Jolt/Math/BVec16.h +0 -99
  183. package/native/third_party/JoltPhysics/Jolt/Math/BVec16.inl +0 -177
  184. package/native/third_party/JoltPhysics/Jolt/Math/DMat44.h +0 -158
  185. package/native/third_party/JoltPhysics/Jolt/Math/DMat44.inl +0 -310
  186. package/native/third_party/JoltPhysics/Jolt/Math/DVec3.h +0 -291
  187. package/native/third_party/JoltPhysics/Jolt/Math/DVec3.inl +0 -941
  188. package/native/third_party/JoltPhysics/Jolt/Math/Double3.h +0 -48
  189. package/native/third_party/JoltPhysics/Jolt/Math/DynMatrix.h +0 -31
  190. package/native/third_party/JoltPhysics/Jolt/Math/EigenValueSymmetric.h +0 -177
  191. package/native/third_party/JoltPhysics/Jolt/Math/FindRoot.h +0 -42
  192. package/native/third_party/JoltPhysics/Jolt/Math/Float2.h +0 -36
  193. package/native/third_party/JoltPhysics/Jolt/Math/Float3.h +0 -50
  194. package/native/third_party/JoltPhysics/Jolt/Math/Float4.h +0 -44
  195. package/native/third_party/JoltPhysics/Jolt/Math/GaussianElimination.h +0 -102
  196. package/native/third_party/JoltPhysics/Jolt/Math/HalfFloat.h +0 -208
  197. package/native/third_party/JoltPhysics/Jolt/Math/Mat44.h +0 -243
  198. package/native/third_party/JoltPhysics/Jolt/Math/Mat44.inl +0 -952
  199. package/native/third_party/JoltPhysics/Jolt/Math/Math.h +0 -208
  200. package/native/third_party/JoltPhysics/Jolt/Math/MathTypes.h +0 -32
  201. package/native/third_party/JoltPhysics/Jolt/Math/Matrix.h +0 -259
  202. package/native/third_party/JoltPhysics/Jolt/Math/Quat.h +0 -268
  203. package/native/third_party/JoltPhysics/Jolt/Math/Quat.inl +0 -406
  204. package/native/third_party/JoltPhysics/Jolt/Math/Real.h +0 -44
  205. package/native/third_party/JoltPhysics/Jolt/Math/Swizzle.h +0 -19
  206. package/native/third_party/JoltPhysics/Jolt/Math/Trigonometry.h +0 -79
  207. package/native/third_party/JoltPhysics/Jolt/Math/UVec4.h +0 -232
  208. package/native/third_party/JoltPhysics/Jolt/Math/UVec4.inl +0 -636
  209. package/native/third_party/JoltPhysics/Jolt/Math/Vec3.cpp +0 -71
  210. package/native/third_party/JoltPhysics/Jolt/Math/Vec3.h +0 -308
  211. package/native/third_party/JoltPhysics/Jolt/Math/Vec3.inl +0 -942
  212. package/native/third_party/JoltPhysics/Jolt/Math/Vec4.h +0 -320
  213. package/native/third_party/JoltPhysics/Jolt/Math/Vec4.inl +0 -1152
  214. package/native/third_party/JoltPhysics/Jolt/Math/Vector.h +0 -211
  215. package/native/third_party/JoltPhysics/Jolt/ObjectStream/GetPrimitiveTypeOfType.h +0 -54
  216. package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStream.cpp +0 -38
  217. package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStream.h +0 -337
  218. package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamBinaryIn.cpp +0 -252
  219. package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamBinaryIn.h +0 -57
  220. package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamBinaryOut.cpp +0 -165
  221. package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamBinaryOut.h +0 -57
  222. package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamIn.cpp +0 -635
  223. package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamIn.h +0 -148
  224. package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamOut.cpp +0 -166
  225. package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamOut.h +0 -101
  226. package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamTextIn.cpp +0 -418
  227. package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamTextIn.h +0 -55
  228. package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamTextOut.cpp +0 -255
  229. package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamTextOut.h +0 -62
  230. package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamTypes.h +0 -26
  231. package/native/third_party/JoltPhysics/Jolt/ObjectStream/SerializableAttribute.h +0 -111
  232. package/native/third_party/JoltPhysics/Jolt/ObjectStream/SerializableAttributeEnum.h +0 -67
  233. package/native/third_party/JoltPhysics/Jolt/ObjectStream/SerializableAttributeTyped.h +0 -60
  234. package/native/third_party/JoltPhysics/Jolt/ObjectStream/SerializableObject.cpp +0 -15
  235. package/native/third_party/JoltPhysics/Jolt/ObjectStream/SerializableObject.h +0 -170
  236. package/native/third_party/JoltPhysics/Jolt/ObjectStream/TypeDeclarations.cpp +0 -70
  237. package/native/third_party/JoltPhysics/Jolt/ObjectStream/TypeDeclarations.h +0 -45
  238. package/native/third_party/JoltPhysics/Jolt/Physics/Body/AllowedDOFs.h +0 -68
  239. package/native/third_party/JoltPhysics/Jolt/Physics/Body/Body.cpp +0 -426
  240. package/native/third_party/JoltPhysics/Jolt/Physics/Body/Body.h +0 -452
  241. package/native/third_party/JoltPhysics/Jolt/Physics/Body/Body.inl +0 -197
  242. package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyAccess.h +0 -68
  243. package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyActivationListener.h +0 -28
  244. package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyCreationSettings.cpp +0 -234
  245. package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyCreationSettings.h +0 -124
  246. package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyFilter.h +0 -130
  247. package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyID.h +0 -101
  248. package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyInterface.cpp +0 -1099
  249. package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyInterface.h +0 -324
  250. package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyLock.h +0 -111
  251. package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyLockInterface.h +0 -134
  252. package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyLockMulti.h +0 -120
  253. package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyManager.cpp +0 -1220
  254. package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyManager.h +0 -403
  255. package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyPair.h +0 -36
  256. package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyType.h +0 -19
  257. package/native/third_party/JoltPhysics/Jolt/Physics/Body/MassProperties.cpp +0 -185
  258. package/native/third_party/JoltPhysics/Jolt/Physics/Body/MassProperties.h +0 -58
  259. package/native/third_party/JoltPhysics/Jolt/Physics/Body/MotionProperties.cpp +0 -92
  260. package/native/third_party/JoltPhysics/Jolt/Physics/Body/MotionProperties.h +0 -308
  261. package/native/third_party/JoltPhysics/Jolt/Physics/Body/MotionProperties.inl +0 -178
  262. package/native/third_party/JoltPhysics/Jolt/Physics/Body/MotionQuality.h +0 -31
  263. package/native/third_party/JoltPhysics/Jolt/Physics/Body/MotionType.h +0 -17
  264. package/native/third_party/JoltPhysics/Jolt/Physics/Character/Character.cpp +0 -354
  265. package/native/third_party/JoltPhysics/Jolt/Physics/Character/Character.h +0 -159
  266. package/native/third_party/JoltPhysics/Jolt/Physics/Character/CharacterBase.cpp +0 -59
  267. package/native/third_party/JoltPhysics/Jolt/Physics/Character/CharacterBase.h +0 -157
  268. package/native/third_party/JoltPhysics/Jolt/Physics/Character/CharacterID.h +0 -98
  269. package/native/third_party/JoltPhysics/Jolt/Physics/Character/CharacterVirtual.cpp +0 -1933
  270. package/native/third_party/JoltPhysics/Jolt/Physics/Character/CharacterVirtual.h +0 -752
  271. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/AABoxCast.h +0 -20
  272. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/ActiveEdgeMode.h +0 -17
  273. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/ActiveEdges.h +0 -114
  274. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BackFaceMode.h +0 -16
  275. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/BroadPhase.cpp +0 -16
  276. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/BroadPhase.h +0 -109
  277. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/BroadPhaseBruteForce.cpp +0 -313
  278. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/BroadPhaseBruteForce.h +0 -38
  279. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/BroadPhaseLayer.h +0 -148
  280. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/BroadPhaseLayerInterfaceMask.h +0 -92
  281. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/BroadPhaseLayerInterfaceTable.h +0 -64
  282. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/BroadPhaseQuadTree.cpp +0 -629
  283. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/BroadPhaseQuadTree.h +0 -108
  284. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/BroadPhaseQuery.h +0 -56
  285. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/ObjectVsBroadPhaseLayerFilterMask.h +0 -35
  286. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/ObjectVsBroadPhaseLayerFilterTable.h +0 -66
  287. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/QuadTree.cpp +0 -1768
  288. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/QuadTree.h +0 -389
  289. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CastConvexVsTriangles.cpp +0 -107
  290. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CastConvexVsTriangles.h +0 -46
  291. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CastResult.h +0 -37
  292. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CastSphereVsTriangles.cpp +0 -223
  293. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CastSphereVsTriangles.h +0 -49
  294. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollectFacesMode.h +0 -16
  295. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollideConvexVsTriangles.cpp +0 -155
  296. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollideConvexVsTriangles.h +0 -56
  297. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollidePointResult.h +0 -25
  298. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollideShape.h +0 -106
  299. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollideShapeVsShapePerLeaf.h +0 -94
  300. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollideSoftBodyVertexIterator.h +0 -110
  301. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollideSoftBodyVerticesVsTriangles.h +0 -102
  302. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollideSphereVsTriangles.cpp +0 -121
  303. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollideSphereVsTriangles.h +0 -50
  304. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollisionCollector.h +0 -109
  305. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollisionCollectorImpl.h +0 -219
  306. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollisionDispatch.cpp +0 -107
  307. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollisionDispatch.h +0 -97
  308. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollisionGroup.cpp +0 -35
  309. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollisionGroup.h +0 -97
  310. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/ContactListener.h +0 -143
  311. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/EstimateCollisionResponse.cpp +0 -213
  312. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/EstimateCollisionResponse.h +0 -48
  313. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/GroupFilter.cpp +0 -32
  314. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/GroupFilter.h +0 -46
  315. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/GroupFilterTable.cpp +0 -38
  316. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/GroupFilterTable.h +0 -130
  317. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/InternalEdgeRemovingCollector.h +0 -279
  318. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/ManifoldBetweenTwoFaces.cpp +0 -271
  319. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/ManifoldBetweenTwoFaces.h +0 -44
  320. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/NarrowPhaseQuery.cpp +0 -448
  321. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/NarrowPhaseQuery.h +0 -77
  322. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/NarrowPhaseStats.cpp +0 -62
  323. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/NarrowPhaseStats.h +0 -110
  324. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/ObjectLayer.h +0 -111
  325. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/ObjectLayerPairFilterMask.h +0 -52
  326. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/ObjectLayerPairFilterTable.h +0 -78
  327. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/PhysicsMaterial.cpp +0 -35
  328. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/PhysicsMaterial.h +0 -57
  329. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/PhysicsMaterialSimple.cpp +0 -38
  330. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/PhysicsMaterialSimple.h +0 -37
  331. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/RayCast.h +0 -87
  332. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/BoxShape.cpp +0 -318
  333. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/BoxShape.h +0 -115
  334. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/CapsuleShape.cpp +0 -438
  335. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/CapsuleShape.h +0 -129
  336. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/CompoundShape.cpp +0 -433
  337. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/CompoundShape.h +0 -354
  338. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/CompoundShapeVisitors.h +0 -461
  339. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/ConvexHullShape.cpp +0 -1311
  340. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/ConvexHullShape.h +0 -202
  341. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/ConvexShape.cpp +0 -566
  342. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/ConvexShape.h +0 -150
  343. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/CylinderShape.cpp +0 -418
  344. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/CylinderShape.h +0 -126
  345. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/DecoratedShape.cpp +0 -87
  346. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/DecoratedShape.h +0 -80
  347. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/EmptyShape.cpp +0 -64
  348. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/EmptyShape.h +0 -75
  349. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/GetTrianglesContext.h +0 -248
  350. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/HeightFieldShape.cpp +0 -2754
  351. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/HeightFieldShape.h +0 -380
  352. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/MeshShape.cpp +0 -1305
  353. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/MeshShape.h +0 -228
  354. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/MutableCompoundShape.cpp +0 -596
  355. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/MutableCompoundShape.h +0 -176
  356. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/OffsetCenterOfMassShape.cpp +0 -217
  357. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/OffsetCenterOfMassShape.h +0 -140
  358. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/PlaneShape.cpp +0 -541
  359. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/PlaneShape.h +0 -147
  360. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/PolyhedronSubmergedVolumeCalculator.h +0 -319
  361. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/RotatedTranslatedShape.cpp +0 -333
  362. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/RotatedTranslatedShape.h +0 -161
  363. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/ScaleHelpers.h +0 -83
  364. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/ScaledShape.cpp +0 -238
  365. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/ScaledShape.h +0 -145
  366. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/Shape.cpp +0 -325
  367. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/Shape.h +0 -466
  368. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/SphereShape.cpp +0 -347
  369. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/SphereShape.h +0 -125
  370. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/StaticCompoundShape.cpp +0 -674
  371. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/StaticCompoundShape.h +0 -139
  372. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/SubShapeID.h +0 -138
  373. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/SubShapeIDPair.h +0 -65
  374. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/TaperedCapsuleShape.cpp +0 -453
  375. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/TaperedCapsuleShape.gliffy +0 -1
  376. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/TaperedCapsuleShape.h +0 -135
  377. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/TaperedCylinderShape.cpp +0 -691
  378. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/TaperedCylinderShape.h +0 -132
  379. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/TriangleShape.cpp +0 -430
  380. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/TriangleShape.h +0 -143
  381. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/ShapeCast.h +0 -173
  382. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/ShapeFilter.h +0 -73
  383. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/SimShapeFilter.h +0 -40
  384. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/SimShapeFilterWrapper.h +0 -58
  385. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/SortReverseAndStore.h +0 -48
  386. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/TransformedShape.cpp +0 -180
  387. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/TransformedShape.h +0 -194
  388. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/CalculateSolverSteps.h +0 -70
  389. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConeConstraint.cpp +0 -246
  390. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConeConstraint.h +0 -133
  391. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/Constraint.cpp +0 -73
  392. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/Constraint.h +0 -243
  393. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintManager.cpp +0 -289
  394. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintManager.h +0 -100
  395. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/AngleConstraintPart.h +0 -257
  396. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/AxisConstraintPart.h +0 -682
  397. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/DualAxisConstraintPart.h +0 -276
  398. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/GearConstraintPart.h +0 -195
  399. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/HingeRotationConstraintPart.h +0 -222
  400. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/IndependentAxisConstraintPart.h +0 -246
  401. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/PointConstraintPart.h +0 -239
  402. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/RackAndPinionConstraintPart.h +0 -196
  403. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/RotationEulerConstraintPart.h +0 -283
  404. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/RotationQuatConstraintPart.h +0 -246
  405. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/SpringPart.h +0 -169
  406. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/SwingTwistConstraintPart.h +0 -597
  407. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ContactConstraintManager.cpp +0 -1804
  408. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ContactConstraintManager.h +0 -524
  409. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/DistanceConstraint.cpp +0 -266
  410. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/DistanceConstraint.h +0 -120
  411. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/FixedConstraint.cpp +0 -215
  412. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/FixedConstraint.h +0 -96
  413. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/GearConstraint.cpp +0 -188
  414. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/GearConstraint.h +0 -116
  415. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/HingeConstraint.cpp +0 -443
  416. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/HingeConstraint.h +0 -205
  417. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/MotorSettings.cpp +0 -43
  418. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/MotorSettings.h +0 -66
  419. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/PathConstraint.cpp +0 -458
  420. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/PathConstraint.h +0 -191
  421. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/PathConstraintPath.cpp +0 -85
  422. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/PathConstraintPath.h +0 -76
  423. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/PathConstraintPathHermite.cpp +0 -308
  424. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/PathConstraintPathHermite.h +0 -54
  425. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/PointConstraint.cpp +0 -157
  426. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/PointConstraint.h +0 -94
  427. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/PulleyConstraint.cpp +0 -253
  428. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/PulleyConstraint.h +0 -137
  429. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/RackAndPinionConstraint.cpp +0 -189
  430. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/RackAndPinionConstraint.h +0 -118
  431. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/SixDOFConstraint.cpp +0 -900
  432. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/SixDOFConstraint.h +0 -289
  433. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/SliderConstraint.cpp +0 -501
  434. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/SliderConstraint.h +0 -198
  435. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/SpringSettings.cpp +0 -35
  436. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/SpringSettings.h +0 -70
  437. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/SwingTwistConstraint.cpp +0 -524
  438. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/SwingTwistConstraint.h +0 -197
  439. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/TwoBodyConstraint.cpp +0 -56
  440. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/TwoBodyConstraint.h +0 -65
  441. package/native/third_party/JoltPhysics/Jolt/Physics/DeterminismLog.cpp +0 -17
  442. package/native/third_party/JoltPhysics/Jolt/Physics/DeterminismLog.h +0 -159
  443. package/native/third_party/JoltPhysics/Jolt/Physics/EActivation.h +0 -16
  444. package/native/third_party/JoltPhysics/Jolt/Physics/EPhysicsUpdateError.h +0 -37
  445. package/native/third_party/JoltPhysics/Jolt/Physics/IslandBuilder.cpp +0 -492
  446. package/native/third_party/JoltPhysics/Jolt/Physics/IslandBuilder.h +0 -144
  447. package/native/third_party/JoltPhysics/Jolt/Physics/LargeIslandSplitter.cpp +0 -582
  448. package/native/third_party/JoltPhysics/Jolt/Physics/LargeIslandSplitter.h +0 -187
  449. package/native/third_party/JoltPhysics/Jolt/Physics/PhysicsLock.h +0 -169
  450. package/native/third_party/JoltPhysics/Jolt/Physics/PhysicsScene.cpp +0 -261
  451. package/native/third_party/JoltPhysics/Jolt/Physics/PhysicsScene.h +0 -104
  452. package/native/third_party/JoltPhysics/Jolt/Physics/PhysicsSettings.h +0 -125
  453. package/native/third_party/JoltPhysics/Jolt/Physics/PhysicsStepListener.h +0 -37
  454. package/native/third_party/JoltPhysics/Jolt/Physics/PhysicsSystem.cpp +0 -2915
  455. package/native/third_party/JoltPhysics/Jolt/Physics/PhysicsSystem.h +0 -391
  456. package/native/third_party/JoltPhysics/Jolt/Physics/PhysicsUpdateContext.cpp +0 -25
  457. package/native/third_party/JoltPhysics/Jolt/Physics/PhysicsUpdateContext.h +0 -176
  458. package/native/third_party/JoltPhysics/Jolt/Physics/Ragdoll/Ragdoll.cpp +0 -744
  459. package/native/third_party/JoltPhysics/Jolt/Physics/Ragdoll/Ragdoll.h +0 -245
  460. package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodyContactListener.h +0 -55
  461. package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodyCreationSettings.cpp +0 -128
  462. package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodyCreationSettings.h +0 -75
  463. package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodyManifold.h +0 -74
  464. package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodyMotionProperties.cpp +0 -1501
  465. package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodyMotionProperties.h +0 -333
  466. package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodyShape.cpp +0 -354
  467. package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodyShape.h +0 -73
  468. package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodySharedSettings.cpp +0 -1487
  469. package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodySharedSettings.h +0 -390
  470. package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodyUpdateContext.h +0 -63
  471. package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodyVertex.h +0 -36
  472. package/native/third_party/JoltPhysics/Jolt/Physics/StateRecorder.h +0 -136
  473. package/native/third_party/JoltPhysics/Jolt/Physics/StateRecorderImpl.cpp +0 -90
  474. package/native/third_party/JoltPhysics/Jolt/Physics/StateRecorderImpl.h +0 -50
  475. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/MotorcycleController.cpp +0 -306
  476. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/MotorcycleController.h +0 -119
  477. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/TrackedVehicleController.cpp +0 -547
  478. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/TrackedVehicleController.h +0 -169
  479. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleAntiRollBar.cpp +0 -33
  480. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleAntiRollBar.h +0 -33
  481. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleCollisionTester.cpp +0 -376
  482. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleCollisionTester.h +0 -146
  483. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleConstraint.cpp +0 -703
  484. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleConstraint.h +0 -252
  485. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleController.cpp +0 -17
  486. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleController.h +0 -87
  487. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleDifferential.cpp +0 -81
  488. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleDifferential.h +0 -39
  489. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleEngine.cpp +0 -122
  490. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleEngine.h +0 -93
  491. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleTrack.cpp +0 -52
  492. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleTrack.h +0 -56
  493. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleTransmission.cpp +0 -159
  494. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleTransmission.h +0 -87
  495. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/Wheel.cpp +0 -93
  496. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/Wheel.h +0 -148
  497. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/WheeledVehicleController.cpp +0 -866
  498. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/WheeledVehicleController.h +0 -205
  499. package/native/third_party/JoltPhysics/Jolt/RegisterTypes.cpp +0 -204
  500. package/native/third_party/JoltPhysics/Jolt/RegisterTypes.h +0 -29
  501. package/native/third_party/JoltPhysics/Jolt/Renderer/DebugRenderer.cpp +0 -1107
  502. package/native/third_party/JoltPhysics/Jolt/Renderer/DebugRenderer.h +0 -383
  503. package/native/third_party/JoltPhysics/Jolt/Renderer/DebugRendererPlayback.cpp +0 -168
  504. package/native/third_party/JoltPhysics/Jolt/Renderer/DebugRendererPlayback.h +0 -48
  505. package/native/third_party/JoltPhysics/Jolt/Renderer/DebugRendererRecorder.cpp +0 -158
  506. package/native/third_party/JoltPhysics/Jolt/Renderer/DebugRendererRecorder.h +0 -130
  507. package/native/third_party/JoltPhysics/Jolt/Renderer/DebugRendererSimple.cpp +0 -80
  508. package/native/third_party/JoltPhysics/Jolt/Renderer/DebugRendererSimple.h +0 -88
  509. package/native/third_party/JoltPhysics/Jolt/Skeleton/SkeletalAnimation.cpp +0 -165
  510. package/native/third_party/JoltPhysics/Jolt/Skeleton/SkeletalAnimation.h +0 -91
  511. package/native/third_party/JoltPhysics/Jolt/Skeleton/Skeleton.cpp +0 -82
  512. package/native/third_party/JoltPhysics/Jolt/Skeleton/Skeleton.h +0 -72
  513. package/native/third_party/JoltPhysics/Jolt/Skeleton/SkeletonMapper.cpp +0 -237
  514. package/native/third_party/JoltPhysics/Jolt/Skeleton/SkeletonMapper.h +0 -145
  515. package/native/third_party/JoltPhysics/Jolt/Skeleton/SkeletonPose.cpp +0 -87
  516. package/native/third_party/JoltPhysics/Jolt/Skeleton/SkeletonPose.h +0 -82
  517. package/native/third_party/JoltPhysics/Jolt/TriangleSplitter/TriangleSplitter.cpp +0 -73
  518. package/native/third_party/JoltPhysics/Jolt/TriangleSplitter/TriangleSplitter.h +0 -84
  519. package/native/third_party/JoltPhysics/Jolt/TriangleSplitter/TriangleSplitterBinning.cpp +0 -139
  520. package/native/third_party/JoltPhysics/Jolt/TriangleSplitter/TriangleSplitterBinning.h +0 -52
  521. package/native/third_party/JoltPhysics/Jolt/TriangleSplitter/TriangleSplitterMean.cpp +0 -43
  522. package/native/third_party/JoltPhysics/Jolt/TriangleSplitter/TriangleSplitterMean.h +0 -28
  523. package/native/third_party/JoltPhysics/LICENSE +0 -7
  524. package/native/third_party/JoltPhysics/README.md +0 -173
  525. package/native/third_party/bloom_jolt/CMakeLists.txt +0 -87
  526. package/native/third_party/bloom_jolt/include/bloom_jolt.h +0 -519
  527. package/native/third_party/bloom_jolt/src/bloom_jolt.cpp +0 -1780
@@ -1,942 +0,0 @@
1
- // Jolt Physics Library (https://github.com/jrouwe/JoltPhysics)
2
- // SPDX-FileCopyrightText: 2021 Jorrit Rouwe
3
- // SPDX-License-Identifier: MIT
4
-
5
- #include <Jolt/Math/Vec4.h>
6
- #include <Jolt/Math/UVec4.h>
7
- #include <Jolt/Core/HashCombine.h>
8
-
9
- JPH_SUPPRESS_WARNINGS_STD_BEGIN
10
- #include <random>
11
- JPH_SUPPRESS_WARNINGS_STD_END
12
-
13
- // Create a std::hash/JPH::Hash for Vec3
14
- JPH_MAKE_HASHABLE(JPH::Vec3, t.GetX(), t.GetY(), t.GetZ())
15
-
16
- JPH_NAMESPACE_BEGIN
17
-
18
- void Vec3::CheckW() const
19
- {
20
- #ifdef JPH_FLOATING_POINT_EXCEPTIONS_ENABLED
21
- // Avoid asserts when both components are NaN
22
- JPH_ASSERT(reinterpret_cast<const uint32 *>(mF32)[2] == reinterpret_cast<const uint32 *>(mF32)[3]);
23
- #endif // JPH_FLOATING_POINT_EXCEPTIONS_ENABLED
24
- }
25
-
26
- JPH_INLINE Vec3::Type Vec3::sFixW(Type inValue)
27
- {
28
- #ifdef JPH_FLOATING_POINT_EXCEPTIONS_ENABLED
29
- #if defined(JPH_USE_SSE)
30
- return _mm_shuffle_ps(inValue, inValue, _MM_SHUFFLE(2, 2, 1, 0));
31
- #elif defined(JPH_USE_NEON)
32
- return JPH_NEON_SHUFFLE_F32x4(inValue, inValue, 0, 1, 2, 2);
33
- #else
34
- Type value;
35
- value.mData[0] = inValue.mData[0];
36
- value.mData[1] = inValue.mData[1];
37
- value.mData[2] = inValue.mData[2];
38
- value.mData[3] = inValue.mData[2];
39
- return value;
40
- #endif
41
- #else
42
- return inValue;
43
- #endif // JPH_FLOATING_POINT_EXCEPTIONS_ENABLED
44
- }
45
-
46
- Vec3::Vec3(Vec4Arg inRHS) :
47
- mValue(sFixW(inRHS.mValue))
48
- {
49
- }
50
-
51
- Vec3::Vec3(const Float3 &inV)
52
- {
53
- #if defined(JPH_USE_SSE)
54
- Type x = _mm_load_ss(&inV.x);
55
- Type y = _mm_load_ss(&inV.y);
56
- Type z = _mm_load_ss(&inV.z);
57
- Type xy = _mm_unpacklo_ps(x, y);
58
- mValue = _mm_shuffle_ps(xy, z, _MM_SHUFFLE(0, 0, 1, 0)); // Assure Z and W are the same
59
- #elif defined(JPH_USE_NEON)
60
- float32x2_t xy = vld1_f32(&inV.x);
61
- float32x2_t zz = vdup_n_f32(inV.z); // Assure Z and W are the same
62
- mValue = vcombine_f32(xy, zz);
63
- #else
64
- mF32[0] = inV[0];
65
- mF32[1] = inV[1];
66
- mF32[2] = inV[2];
67
- mF32[3] = inV[2]; // Not strictly needed when JPH_FLOATING_POINT_EXCEPTIONS_ENABLED is off but prevents warnings about uninitialized variables
68
- #endif
69
- }
70
-
71
- Vec3::Vec3(float inX, float inY, float inZ)
72
- {
73
- #if defined(JPH_USE_SSE)
74
- mValue = _mm_set_ps(inZ, inZ, inY, inX);
75
- #elif defined(JPH_USE_NEON)
76
- uint32x2_t xy = vcreate_u32(static_cast<uint64>(BitCast<uint32>(inX)) | (static_cast<uint64>(BitCast<uint32>(inY)) << 32));
77
- uint32x2_t zz = vreinterpret_u32_f32(vdup_n_f32(inZ));
78
- mValue = vreinterpretq_f32_u32(vcombine_u32(xy, zz));
79
- #else
80
- mF32[0] = inX;
81
- mF32[1] = inY;
82
- mF32[2] = inZ;
83
- mF32[3] = inZ; // Not strictly needed when JPH_FLOATING_POINT_EXCEPTIONS_ENABLED is off but prevents warnings about uninitialized variables
84
- #endif
85
- }
86
-
87
- template<uint32 SwizzleX, uint32 SwizzleY, uint32 SwizzleZ>
88
- Vec3 Vec3::Swizzle() const
89
- {
90
- static_assert(SwizzleX <= 3, "SwizzleX template parameter out of range");
91
- static_assert(SwizzleY <= 3, "SwizzleY template parameter out of range");
92
- static_assert(SwizzleZ <= 3, "SwizzleZ template parameter out of range");
93
-
94
- #if defined(JPH_USE_SSE)
95
- return _mm_shuffle_ps(mValue, mValue, _MM_SHUFFLE(SwizzleZ, SwizzleZ, SwizzleY, SwizzleX)); // Assure Z and W are the same
96
- #elif defined(JPH_USE_NEON)
97
- return JPH_NEON_SHUFFLE_F32x4(mValue, mValue, SwizzleX, SwizzleY, SwizzleZ, SwizzleZ);
98
- #else
99
- return Vec3(mF32[SwizzleX], mF32[SwizzleY], mF32[SwizzleZ]);
100
- #endif
101
- }
102
-
103
- Vec3 Vec3::sZero()
104
- {
105
- #if defined(JPH_USE_SSE)
106
- return _mm_setzero_ps();
107
- #elif defined(JPH_USE_NEON)
108
- return vdupq_n_f32(0);
109
- #else
110
- return Vec3(0, 0, 0);
111
- #endif
112
- }
113
-
114
- Vec3 Vec3::sReplicate(float inV)
115
- {
116
- #if defined(JPH_USE_SSE)
117
- return _mm_set1_ps(inV);
118
- #elif defined(JPH_USE_NEON)
119
- return vdupq_n_f32(inV);
120
- #else
121
- return Vec3(inV, inV, inV);
122
- #endif
123
- }
124
-
125
- Vec3 Vec3::sOne()
126
- {
127
- return sReplicate(1.0f);
128
- }
129
-
130
- Vec3 Vec3::sNaN()
131
- {
132
- return sReplicate(numeric_limits<float>::quiet_NaN());
133
- }
134
-
135
- Vec3 Vec3::sLoadFloat3Unsafe(const Float3 &inV)
136
- {
137
- #if defined(JPH_USE_SSE)
138
- Type v = _mm_loadu_ps(&inV.x);
139
- #elif defined(JPH_USE_NEON)
140
- Type v = vld1q_f32(&inV.x);
141
- #else
142
- Type v = { inV.x, inV.y, inV.z };
143
- #endif
144
- return sFixW(v);
145
- }
146
-
147
- Vec3 Vec3::sMin(Vec3Arg inV1, Vec3Arg inV2)
148
- {
149
- #if defined(JPH_USE_SSE)
150
- return _mm_min_ps(inV1.mValue, inV2.mValue);
151
- #elif defined(JPH_USE_NEON)
152
- return vminq_f32(inV1.mValue, inV2.mValue);
153
- #else
154
- return Vec3(min(inV1.mF32[0], inV2.mF32[0]),
155
- min(inV1.mF32[1], inV2.mF32[1]),
156
- min(inV1.mF32[2], inV2.mF32[2]));
157
- #endif
158
- }
159
-
160
- Vec3 Vec3::sMax(Vec3Arg inV1, Vec3Arg inV2)
161
- {
162
- #if defined(JPH_USE_SSE)
163
- return _mm_max_ps(inV1.mValue, inV2.mValue);
164
- #elif defined(JPH_USE_NEON)
165
- return vmaxq_f32(inV1.mValue, inV2.mValue);
166
- #else
167
- return Vec3(max(inV1.mF32[0], inV2.mF32[0]),
168
- max(inV1.mF32[1], inV2.mF32[1]),
169
- max(inV1.mF32[2], inV2.mF32[2]));
170
- #endif
171
- }
172
-
173
- Vec3 Vec3::sClamp(Vec3Arg inV, Vec3Arg inMin, Vec3Arg inMax)
174
- {
175
- return sMax(sMin(inV, inMax), inMin);
176
- }
177
-
178
- UVec4 Vec3::sEquals(Vec3Arg inV1, Vec3Arg inV2)
179
- {
180
- #if defined(JPH_USE_SSE)
181
- return _mm_castps_si128(_mm_cmpeq_ps(inV1.mValue, inV2.mValue));
182
- #elif defined(JPH_USE_NEON)
183
- return vceqq_f32(inV1.mValue, inV2.mValue);
184
- #else
185
- uint32 z = inV1.mF32[2] == inV2.mF32[2]? 0xffffffffu : 0;
186
- return UVec4(inV1.mF32[0] == inV2.mF32[0]? 0xffffffffu : 0,
187
- inV1.mF32[1] == inV2.mF32[1]? 0xffffffffu : 0,
188
- z,
189
- z);
190
- #endif
191
- }
192
-
193
- UVec4 Vec3::sLess(Vec3Arg inV1, Vec3Arg inV2)
194
- {
195
- #if defined(JPH_USE_SSE)
196
- return _mm_castps_si128(_mm_cmplt_ps(inV1.mValue, inV2.mValue));
197
- #elif defined(JPH_USE_NEON)
198
- return vcltq_f32(inV1.mValue, inV2.mValue);
199
- #else
200
- uint32 z = inV1.mF32[2] < inV2.mF32[2]? 0xffffffffu : 0;
201
- return UVec4(inV1.mF32[0] < inV2.mF32[0]? 0xffffffffu : 0,
202
- inV1.mF32[1] < inV2.mF32[1]? 0xffffffffu : 0,
203
- z,
204
- z);
205
- #endif
206
- }
207
-
208
- UVec4 Vec3::sLessOrEqual(Vec3Arg inV1, Vec3Arg inV2)
209
- {
210
- #if defined(JPH_USE_SSE)
211
- return _mm_castps_si128(_mm_cmple_ps(inV1.mValue, inV2.mValue));
212
- #elif defined(JPH_USE_NEON)
213
- return vcleq_f32(inV1.mValue, inV2.mValue);
214
- #else
215
- uint32 z = inV1.mF32[2] <= inV2.mF32[2]? 0xffffffffu : 0;
216
- return UVec4(inV1.mF32[0] <= inV2.mF32[0]? 0xffffffffu : 0,
217
- inV1.mF32[1] <= inV2.mF32[1]? 0xffffffffu : 0,
218
- z,
219
- z);
220
- #endif
221
- }
222
-
223
- UVec4 Vec3::sGreater(Vec3Arg inV1, Vec3Arg inV2)
224
- {
225
- #if defined(JPH_USE_SSE)
226
- return _mm_castps_si128(_mm_cmpgt_ps(inV1.mValue, inV2.mValue));
227
- #elif defined(JPH_USE_NEON)
228
- return vcgtq_f32(inV1.mValue, inV2.mValue);
229
- #else
230
- uint32 z = inV1.mF32[2] > inV2.mF32[2]? 0xffffffffu : 0;
231
- return UVec4(inV1.mF32[0] > inV2.mF32[0]? 0xffffffffu : 0,
232
- inV1.mF32[1] > inV2.mF32[1]? 0xffffffffu : 0,
233
- z,
234
- z);
235
- #endif
236
- }
237
-
238
- UVec4 Vec3::sGreaterOrEqual(Vec3Arg inV1, Vec3Arg inV2)
239
- {
240
- #if defined(JPH_USE_SSE)
241
- return _mm_castps_si128(_mm_cmpge_ps(inV1.mValue, inV2.mValue));
242
- #elif defined(JPH_USE_NEON)
243
- return vcgeq_f32(inV1.mValue, inV2.mValue);
244
- #else
245
- uint32 z = inV1.mF32[2] >= inV2.mF32[2]? 0xffffffffu : 0;
246
- return UVec4(inV1.mF32[0] >= inV2.mF32[0]? 0xffffffffu : 0,
247
- inV1.mF32[1] >= inV2.mF32[1]? 0xffffffffu : 0,
248
- z,
249
- z);
250
- #endif
251
- }
252
-
253
- Vec3 Vec3::sFusedMultiplyAdd(Vec3Arg inMul1, Vec3Arg inMul2, Vec3Arg inAdd)
254
- {
255
- #if defined(JPH_USE_SSE)
256
- #ifdef JPH_USE_FMADD
257
- return _mm_fmadd_ps(inMul1.mValue, inMul2.mValue, inAdd.mValue);
258
- #else
259
- return _mm_add_ps(_mm_mul_ps(inMul1.mValue, inMul2.mValue), inAdd.mValue);
260
- #endif
261
- #elif defined(JPH_USE_NEON)
262
- return vmlaq_f32(inAdd.mValue, inMul1.mValue, inMul2.mValue);
263
- #else
264
- return Vec3(inMul1.mF32[0] * inMul2.mF32[0] + inAdd.mF32[0],
265
- inMul1.mF32[1] * inMul2.mF32[1] + inAdd.mF32[1],
266
- inMul1.mF32[2] * inMul2.mF32[2] + inAdd.mF32[2]);
267
- #endif
268
- }
269
-
270
- Vec3 Vec3::sSelect(Vec3Arg inNotSet, Vec3Arg inSet, UVec4Arg inControl)
271
- {
272
- #if defined(JPH_USE_SSE4_1) && !defined(JPH_PLATFORM_WASM) // _mm_blendv_ps has problems on FireFox
273
- Type v = _mm_blendv_ps(inNotSet.mValue, inSet.mValue, _mm_castsi128_ps(inControl.mValue));
274
- return sFixW(v);
275
- #elif defined(JPH_USE_SSE)
276
- __m128 is_set = _mm_castsi128_ps(_mm_srai_epi32(inControl.mValue, 31));
277
- Type v = _mm_or_ps(_mm_and_ps(is_set, inSet.mValue), _mm_andnot_ps(is_set, inNotSet.mValue));
278
- return sFixW(v);
279
- #elif defined(JPH_USE_NEON)
280
- Type v = vbslq_f32(vreinterpretq_u32_s32(vshrq_n_s32(vreinterpretq_s32_u32(inControl.mValue), 31)), inSet.mValue, inNotSet.mValue);
281
- return sFixW(v);
282
- #else
283
- Vec3 result;
284
- for (int i = 0; i < 3; i++)
285
- result.mF32[i] = (inControl.mU32[i] & 0x80000000u) ? inSet.mF32[i] : inNotSet.mF32[i];
286
- #ifdef JPH_FLOATING_POINT_EXCEPTIONS_ENABLED
287
- result.mF32[3] = result.mF32[2];
288
- #endif // JPH_FLOATING_POINT_EXCEPTIONS_ENABLED
289
- return result;
290
- #endif
291
- }
292
-
293
- Vec3 Vec3::sOr(Vec3Arg inV1, Vec3Arg inV2)
294
- {
295
- #if defined(JPH_USE_SSE)
296
- return _mm_or_ps(inV1.mValue, inV2.mValue);
297
- #elif defined(JPH_USE_NEON)
298
- return vreinterpretq_f32_u32(vorrq_u32(vreinterpretq_u32_f32(inV1.mValue), vreinterpretq_u32_f32(inV2.mValue)));
299
- #else
300
- return Vec3(UVec4::sOr(inV1.ReinterpretAsInt(), inV2.ReinterpretAsInt()).ReinterpretAsFloat());
301
- #endif
302
- }
303
-
304
- Vec3 Vec3::sXor(Vec3Arg inV1, Vec3Arg inV2)
305
- {
306
- #if defined(JPH_USE_SSE)
307
- return _mm_xor_ps(inV1.mValue, inV2.mValue);
308
- #elif defined(JPH_USE_NEON)
309
- return vreinterpretq_f32_u32(veorq_u32(vreinterpretq_u32_f32(inV1.mValue), vreinterpretq_u32_f32(inV2.mValue)));
310
- #else
311
- return Vec3(UVec4::sXor(inV1.ReinterpretAsInt(), inV2.ReinterpretAsInt()).ReinterpretAsFloat());
312
- #endif
313
- }
314
-
315
- Vec3 Vec3::sAnd(Vec3Arg inV1, Vec3Arg inV2)
316
- {
317
- #if defined(JPH_USE_SSE)
318
- return _mm_and_ps(inV1.mValue, inV2.mValue);
319
- #elif defined(JPH_USE_NEON)
320
- return vreinterpretq_f32_u32(vandq_u32(vreinterpretq_u32_f32(inV1.mValue), vreinterpretq_u32_f32(inV2.mValue)));
321
- #else
322
- return Vec3(UVec4::sAnd(inV1.ReinterpretAsInt(), inV2.ReinterpretAsInt()).ReinterpretAsFloat());
323
- #endif
324
- }
325
-
326
- Vec3 Vec3::sUnitSpherical(float inTheta, float inPhi)
327
- {
328
- Vec4 s, c;
329
- Vec4(inTheta, inPhi, 0, 0).SinCos(s, c);
330
- return Vec3(s.GetX() * c.GetY(), s.GetX() * s.GetY(), c.GetX());
331
- }
332
-
333
- template <class Random>
334
- Vec3 Vec3::sRandom(Random &inRandom)
335
- {
336
- std::uniform_real_distribution<float> zero_to_one(0.0f, 1.0f);
337
- float theta = JPH_PI * zero_to_one(inRandom);
338
- float phi = 2.0f * JPH_PI * zero_to_one(inRandom);
339
- return sUnitSpherical(theta, phi);
340
- }
341
-
342
- bool Vec3::operator == (Vec3Arg inV2) const
343
- {
344
- return sEquals(*this, inV2).TestAllXYZTrue();
345
- }
346
-
347
- bool Vec3::IsClose(Vec3Arg inV2, float inMaxDistSq) const
348
- {
349
- return (inV2 - *this).LengthSq() <= inMaxDistSq;
350
- }
351
-
352
- bool Vec3::IsNearZero(float inMaxDistSq) const
353
- {
354
- return LengthSq() <= inMaxDistSq;
355
- }
356
-
357
- Vec3 Vec3::operator * (Vec3Arg inV2) const
358
- {
359
- #if defined(JPH_USE_SSE)
360
- return _mm_mul_ps(mValue, inV2.mValue);
361
- #elif defined(JPH_USE_NEON)
362
- return vmulq_f32(mValue, inV2.mValue);
363
- #else
364
- return Vec3(mF32[0] * inV2.mF32[0], mF32[1] * inV2.mF32[1], mF32[2] * inV2.mF32[2]);
365
- #endif
366
- }
367
-
368
- Vec3 Vec3::operator * (float inV2) const
369
- {
370
- #if defined(JPH_USE_SSE)
371
- return _mm_mul_ps(mValue, _mm_set1_ps(inV2));
372
- #elif defined(JPH_USE_NEON)
373
- return vmulq_n_f32(mValue, inV2);
374
- #else
375
- return Vec3(mF32[0] * inV2, mF32[1] * inV2, mF32[2] * inV2);
376
- #endif
377
- }
378
-
379
- Vec3 operator * (float inV1, Vec3Arg inV2)
380
- {
381
- #if defined(JPH_USE_SSE)
382
- return _mm_mul_ps(_mm_set1_ps(inV1), inV2.mValue);
383
- #elif defined(JPH_USE_NEON)
384
- return vmulq_n_f32(inV2.mValue, inV1);
385
- #else
386
- return Vec3(inV1 * inV2.mF32[0], inV1 * inV2.mF32[1], inV1 * inV2.mF32[2]);
387
- #endif
388
- }
389
-
390
- Vec3 Vec3::operator / (float inV2) const
391
- {
392
- #if defined(JPH_USE_SSE)
393
- return _mm_div_ps(mValue, _mm_set1_ps(inV2));
394
- #elif defined(JPH_USE_NEON)
395
- return vdivq_f32(mValue, vdupq_n_f32(inV2));
396
- #else
397
- return Vec3(mF32[0] / inV2, mF32[1] / inV2, mF32[2] / inV2);
398
- #endif
399
- }
400
-
401
- Vec3 &Vec3::operator *= (float inV2)
402
- {
403
- #if defined(JPH_USE_SSE)
404
- mValue = _mm_mul_ps(mValue, _mm_set1_ps(inV2));
405
- #elif defined(JPH_USE_NEON)
406
- mValue = vmulq_n_f32(mValue, inV2);
407
- #else
408
- for (int i = 0; i < 3; ++i)
409
- mF32[i] *= inV2;
410
- #ifdef JPH_FLOATING_POINT_EXCEPTIONS_ENABLED
411
- mF32[3] = mF32[2];
412
- #endif
413
- #endif
414
- return *this;
415
- }
416
-
417
- Vec3 &Vec3::operator *= (Vec3Arg inV2)
418
- {
419
- #if defined(JPH_USE_SSE)
420
- mValue = _mm_mul_ps(mValue, inV2.mValue);
421
- #elif defined(JPH_USE_NEON)
422
- mValue = vmulq_f32(mValue, inV2.mValue);
423
- #else
424
- for (int i = 0; i < 3; ++i)
425
- mF32[i] *= inV2.mF32[i];
426
- #ifdef JPH_FLOATING_POINT_EXCEPTIONS_ENABLED
427
- mF32[3] = mF32[2];
428
- #endif
429
- #endif
430
- return *this;
431
- }
432
-
433
- Vec3 &Vec3::operator /= (float inV2)
434
- {
435
- #if defined(JPH_USE_SSE)
436
- mValue = _mm_div_ps(mValue, _mm_set1_ps(inV2));
437
- #elif defined(JPH_USE_NEON)
438
- mValue = vdivq_f32(mValue, vdupq_n_f32(inV2));
439
- #else
440
- for (int i = 0; i < 3; ++i)
441
- mF32[i] /= inV2;
442
- #ifdef JPH_FLOATING_POINT_EXCEPTIONS_ENABLED
443
- mF32[3] = mF32[2];
444
- #endif
445
- #endif
446
- return *this;
447
- }
448
-
449
- Vec3 Vec3::operator + (Vec3Arg inV2) const
450
- {
451
- #if defined(JPH_USE_SSE)
452
- return _mm_add_ps(mValue, inV2.mValue);
453
- #elif defined(JPH_USE_NEON)
454
- return vaddq_f32(mValue, inV2.mValue);
455
- #else
456
- return Vec3(mF32[0] + inV2.mF32[0], mF32[1] + inV2.mF32[1], mF32[2] + inV2.mF32[2]);
457
- #endif
458
- }
459
-
460
- Vec3 &Vec3::operator += (Vec3Arg inV2)
461
- {
462
- #if defined(JPH_USE_SSE)
463
- mValue = _mm_add_ps(mValue, inV2.mValue);
464
- #elif defined(JPH_USE_NEON)
465
- mValue = vaddq_f32(mValue, inV2.mValue);
466
- #else
467
- for (int i = 0; i < 3; ++i)
468
- mF32[i] += inV2.mF32[i];
469
- #ifdef JPH_FLOATING_POINT_EXCEPTIONS_ENABLED
470
- mF32[3] = mF32[2];
471
- #endif
472
- #endif
473
- return *this;
474
- }
475
-
476
- Vec3 Vec3::operator - () const
477
- {
478
- #if defined(JPH_USE_SSE)
479
- return _mm_sub_ps(_mm_setzero_ps(), mValue);
480
- #elif defined(JPH_USE_NEON)
481
- #ifdef JPH_CROSS_PLATFORM_DETERMINISTIC
482
- return vsubq_f32(vdupq_n_f32(0), mValue);
483
- #else
484
- return vnegq_f32(mValue);
485
- #endif
486
- #else
487
- #ifdef JPH_CROSS_PLATFORM_DETERMINISTIC
488
- return Vec3(0.0f - mF32[0], 0.0f - mF32[1], 0.0f - mF32[2]);
489
- #else
490
- return Vec3(-mF32[0], -mF32[1], -mF32[2]);
491
- #endif
492
- #endif
493
- }
494
-
495
- Vec3 Vec3::operator - (Vec3Arg inV2) const
496
- {
497
- #if defined(JPH_USE_SSE)
498
- return _mm_sub_ps(mValue, inV2.mValue);
499
- #elif defined(JPH_USE_NEON)
500
- return vsubq_f32(mValue, inV2.mValue);
501
- #else
502
- return Vec3(mF32[0] - inV2.mF32[0], mF32[1] - inV2.mF32[1], mF32[2] - inV2.mF32[2]);
503
- #endif
504
- }
505
-
506
- Vec3 &Vec3::operator -= (Vec3Arg inV2)
507
- {
508
- #if defined(JPH_USE_SSE)
509
- mValue = _mm_sub_ps(mValue, inV2.mValue);
510
- #elif defined(JPH_USE_NEON)
511
- mValue = vsubq_f32(mValue, inV2.mValue);
512
- #else
513
- for (int i = 0; i < 3; ++i)
514
- mF32[i] -= inV2.mF32[i];
515
- #ifdef JPH_FLOATING_POINT_EXCEPTIONS_ENABLED
516
- mF32[3] = mF32[2];
517
- #endif
518
- #endif
519
- return *this;
520
- }
521
-
522
- Vec3 Vec3::operator / (Vec3Arg inV2) const
523
- {
524
- inV2.CheckW(); // Check W equals Z to avoid div by zero
525
- #if defined(JPH_USE_SSE)
526
- return _mm_div_ps(mValue, inV2.mValue);
527
- #elif defined(JPH_USE_NEON)
528
- return vdivq_f32(mValue, inV2.mValue);
529
- #else
530
- return Vec3(mF32[0] / inV2.mF32[0], mF32[1] / inV2.mF32[1], mF32[2] / inV2.mF32[2]);
531
- #endif
532
- }
533
-
534
- Vec4 Vec3::SplatX() const
535
- {
536
- #if defined(JPH_USE_SSE)
537
- return _mm_shuffle_ps(mValue, mValue, _MM_SHUFFLE(0, 0, 0, 0));
538
- #elif defined(JPH_USE_NEON)
539
- return vdupq_laneq_f32(mValue, 0);
540
- #else
541
- return Vec4(mF32[0], mF32[0], mF32[0], mF32[0]);
542
- #endif
543
- }
544
-
545
- Vec4 Vec3::SplatY() const
546
- {
547
- #if defined(JPH_USE_SSE)
548
- return _mm_shuffle_ps(mValue, mValue, _MM_SHUFFLE(1, 1, 1, 1));
549
- #elif defined(JPH_USE_NEON)
550
- return vdupq_laneq_f32(mValue, 1);
551
- #else
552
- return Vec4(mF32[1], mF32[1], mF32[1], mF32[1]);
553
- #endif
554
- }
555
-
556
- Vec4 Vec3::SplatZ() const
557
- {
558
- #if defined(JPH_USE_SSE)
559
- return _mm_shuffle_ps(mValue, mValue, _MM_SHUFFLE(2, 2, 2, 2));
560
- #elif defined(JPH_USE_NEON)
561
- return vdupq_laneq_f32(mValue, 2);
562
- #else
563
- return Vec4(mF32[2], mF32[2], mF32[2], mF32[2]);
564
- #endif
565
- }
566
-
567
- int Vec3::GetLowestComponentIndex() const
568
- {
569
- return GetX() < GetY() ? (GetZ() < GetX() ? 2 : 0) : (GetZ() < GetY() ? 2 : 1);
570
- }
571
-
572
- int Vec3::GetHighestComponentIndex() const
573
- {
574
- return GetX() > GetY() ? (GetZ() > GetX() ? 2 : 0) : (GetZ() > GetY() ? 2 : 1);
575
- }
576
-
577
- Vec3 Vec3::Abs() const
578
- {
579
- #if defined(JPH_USE_AVX512)
580
- return _mm_range_ps(mValue, mValue, 0b1000);
581
- #elif defined(JPH_USE_SSE)
582
- return _mm_max_ps(_mm_sub_ps(_mm_setzero_ps(), mValue), mValue);
583
- #elif defined(JPH_USE_NEON)
584
- return vabsq_f32(mValue);
585
- #else
586
- return Vec3(abs(mF32[0]), abs(mF32[1]), abs(mF32[2]));
587
- #endif
588
- }
589
-
590
- Vec3 Vec3::Reciprocal() const
591
- {
592
- return sOne() / mValue;
593
- }
594
-
595
- Vec3 Vec3::Cross(Vec3Arg inV2) const
596
- {
597
- #if defined(JPH_USE_SSE)
598
- Type t1 = _mm_shuffle_ps(inV2.mValue, inV2.mValue, _MM_SHUFFLE(0, 0, 2, 1)); // Assure Z and W are the same
599
- t1 = _mm_mul_ps(t1, mValue);
600
- Type t2 = _mm_shuffle_ps(mValue, mValue, _MM_SHUFFLE(0, 0, 2, 1)); // Assure Z and W are the same
601
- t2 = _mm_mul_ps(t2, inV2.mValue);
602
- Type t3 = _mm_sub_ps(t1, t2);
603
- return _mm_shuffle_ps(t3, t3, _MM_SHUFFLE(0, 0, 2, 1)); // Assure Z and W are the same
604
- #elif defined(JPH_USE_NEON)
605
- Type t1 = JPH_NEON_SHUFFLE_F32x4(inV2.mValue, inV2.mValue, 1, 2, 0, 0); // Assure Z and W are the same
606
- t1 = vmulq_f32(t1, mValue);
607
- Type t2 = JPH_NEON_SHUFFLE_F32x4(mValue, mValue, 1, 2, 0, 0); // Assure Z and W are the same
608
- t2 = vmulq_f32(t2, inV2.mValue);
609
- Type t3 = vsubq_f32(t1, t2);
610
- return JPH_NEON_SHUFFLE_F32x4(t3, t3, 1, 2, 0, 0); // Assure Z and W are the same
611
- #else
612
- return Vec3(mF32[1] * inV2.mF32[2] - mF32[2] * inV2.mF32[1],
613
- mF32[2] * inV2.mF32[0] - mF32[0] * inV2.mF32[2],
614
- mF32[0] * inV2.mF32[1] - mF32[1] * inV2.mF32[0]);
615
- #endif
616
- }
617
-
618
- Vec3 Vec3::DotV(Vec3Arg inV2) const
619
- {
620
- #if defined(JPH_USE_SSE4_1)
621
- return _mm_dp_ps(mValue, inV2.mValue, 0x7f);
622
- #elif defined(JPH_USE_NEON)
623
- float32x4_t mul = vmulq_f32(mValue, inV2.mValue);
624
- mul = vsetq_lane_f32(0, mul, 3);
625
- return vdupq_n_f32(vaddvq_f32(mul));
626
- #else
627
- float dot = 0.0f;
628
- for (int i = 0; i < 3; i++)
629
- dot += mF32[i] * inV2.mF32[i];
630
- return Vec3::sReplicate(dot);
631
- #endif
632
- }
633
-
634
- Vec4 Vec3::DotV4(Vec3Arg inV2) const
635
- {
636
- #if defined(JPH_USE_SSE4_1)
637
- return _mm_dp_ps(mValue, inV2.mValue, 0x7f);
638
- #elif defined(JPH_USE_NEON)
639
- float32x4_t mul = vmulq_f32(mValue, inV2.mValue);
640
- mul = vsetq_lane_f32(0, mul, 3);
641
- return vdupq_n_f32(vaddvq_f32(mul));
642
- #else
643
- float dot = 0.0f;
644
- for (int i = 0; i < 3; i++)
645
- dot += mF32[i] * inV2.mF32[i];
646
- return Vec4::sReplicate(dot);
647
- #endif
648
- }
649
-
650
- float Vec3::Dot(Vec3Arg inV2) const
651
- {
652
- #if defined(JPH_USE_SSE4_1)
653
- return _mm_cvtss_f32(_mm_dp_ps(mValue, inV2.mValue, 0x7f));
654
- #elif defined(JPH_USE_NEON)
655
- float32x4_t mul = vmulq_f32(mValue, inV2.mValue);
656
- mul = vsetq_lane_f32(0, mul, 3);
657
- return vaddvq_f32(mul);
658
- #else
659
- float dot = 0.0f;
660
- for (int i = 0; i < 3; i++)
661
- dot += mF32[i] * inV2.mF32[i];
662
- return dot;
663
- #endif
664
- }
665
-
666
- float Vec3::LengthSq() const
667
- {
668
- #if defined(JPH_USE_SSE4_1)
669
- return _mm_cvtss_f32(_mm_dp_ps(mValue, mValue, 0x7f));
670
- #elif defined(JPH_USE_NEON)
671
- float32x4_t mul = vmulq_f32(mValue, mValue);
672
- mul = vsetq_lane_f32(0, mul, 3);
673
- return vaddvq_f32(mul);
674
- #else
675
- float len_sq = 0.0f;
676
- for (int i = 0; i < 3; i++)
677
- len_sq += mF32[i] * mF32[i];
678
- return len_sq;
679
- #endif
680
- }
681
-
682
- float Vec3::Length() const
683
- {
684
- #if defined(JPH_USE_SSE4_1)
685
- return _mm_cvtss_f32(_mm_sqrt_ss(_mm_dp_ps(mValue, mValue, 0x7f)));
686
- #elif defined(JPH_USE_NEON)
687
- float32x4_t mul = vmulq_f32(mValue, mValue);
688
- mul = vsetq_lane_f32(0, mul, 3);
689
- float32x2_t sum = vdup_n_f32(vaddvq_f32(mul));
690
- return vget_lane_f32(vsqrt_f32(sum), 0);
691
- #else
692
- return sqrt(LengthSq());
693
- #endif
694
- }
695
-
696
- Vec3 Vec3::Sqrt() const
697
- {
698
- #if defined(JPH_USE_SSE)
699
- return _mm_sqrt_ps(mValue);
700
- #elif defined(JPH_USE_NEON)
701
- return vsqrtq_f32(mValue);
702
- #else
703
- return Vec3(sqrt(mF32[0]), sqrt(mF32[1]), sqrt(mF32[2]));
704
- #endif
705
- }
706
-
707
- Vec3 Vec3::Normalized() const
708
- {
709
- #if defined(JPH_USE_SSE4_1)
710
- return _mm_div_ps(mValue, _mm_sqrt_ps(_mm_dp_ps(mValue, mValue, 0x7f)));
711
- #elif defined(JPH_USE_NEON)
712
- float32x4_t mul = vmulq_f32(mValue, mValue);
713
- mul = vsetq_lane_f32(0, mul, 3);
714
- float32x4_t sum = vdupq_n_f32(vaddvq_f32(mul));
715
- return vdivq_f32(mValue, vsqrtq_f32(sum));
716
- #else
717
- return *this / Length();
718
- #endif
719
- }
720
-
721
- Vec3 Vec3::NormalizedOr(Vec3Arg inZeroValue) const
722
- {
723
- #if defined(JPH_USE_SSE4_1) && !defined(JPH_PLATFORM_WASM) // _mm_blendv_ps has problems on FireFox
724
- Type len_sq = _mm_dp_ps(mValue, mValue, 0x7f);
725
- // clang with '-ffast-math' (which you should not use!) can generate _mm_rsqrt_ps
726
- // instructions which produce INFs/NaNs when they get a denormal float as input.
727
- // We therefore treat denormals as zero here.
728
- Type is_zero = _mm_cmple_ps(len_sq, _mm_set1_ps(FLT_MIN));
729
- #ifdef JPH_FLOATING_POINT_EXCEPTIONS_ENABLED
730
- if (_mm_movemask_ps(is_zero) == 0xf)
731
- return inZeroValue;
732
- else
733
- return _mm_div_ps(mValue, _mm_sqrt_ps(len_sq));
734
- #else
735
- return _mm_blendv_ps(_mm_div_ps(mValue, _mm_sqrt_ps(len_sq)), inZeroValue.mValue, is_zero);
736
- #endif // JPH_FLOATING_POINT_EXCEPTIONS_ENABLED
737
- #elif defined(JPH_USE_NEON)
738
- float32x4_t mul = vmulq_f32(mValue, mValue);
739
- mul = vsetq_lane_f32(0, mul, 3);
740
- float32x4_t len_sq = vdupq_n_f32(vaddvq_f32(mul));
741
- uint32x4_t is_zero = vcleq_f32(len_sq, vdupq_n_f32(FLT_MIN));
742
- return vbslq_f32(is_zero, inZeroValue.mValue, vdivq_f32(mValue, vsqrtq_f32(len_sq)));
743
- #else
744
- float len_sq = LengthSq();
745
- if (len_sq <= FLT_MIN)
746
- return inZeroValue;
747
- else
748
- return *this / sqrt(len_sq);
749
- #endif
750
- }
751
-
752
- bool Vec3::IsNormalized(float inTolerance) const
753
- {
754
- return abs(LengthSq() - 1.0f) <= inTolerance;
755
- }
756
-
757
- bool Vec3::IsNaN() const
758
- {
759
- #if defined(JPH_USE_AVX512)
760
- return (_mm_fpclass_ps_mask(mValue, 0b10000001) & 0x7) != 0;
761
- #elif defined(JPH_USE_SSE)
762
- return (_mm_movemask_ps(_mm_cmpunord_ps(mValue, mValue)) & 0x7) != 0;
763
- #elif defined(JPH_USE_NEON)
764
- uint32x4_t mask = JPH_NEON_UINT32x4(1, 1, 1, 0);
765
- uint32x4_t is_equal = vceqq_f32(mValue, mValue); // If a number is not equal to itself it's a NaN
766
- return vaddvq_u32(vandq_u32(is_equal, mask)) != 3;
767
- #else
768
- return isnan(mF32[0]) || isnan(mF32[1]) || isnan(mF32[2]);
769
- #endif
770
- }
771
-
772
- void Vec3::StoreFloat3(Float3 *outV) const
773
- {
774
- #if defined(JPH_USE_SSE)
775
- _mm_store_ss(&outV->x, mValue);
776
- Vec3 t = Swizzle<SWIZZLE_Y, SWIZZLE_Z, SWIZZLE_UNUSED>();
777
- _mm_store_ss(&outV->y, t.mValue);
778
- t = t.Swizzle<SWIZZLE_Y, SWIZZLE_UNUSED, SWIZZLE_UNUSED>();
779
- _mm_store_ss(&outV->z, t.mValue);
780
- #elif defined(JPH_USE_NEON)
781
- float32x2_t xy = vget_low_f32(mValue);
782
- vst1_f32(&outV->x, xy);
783
- vst1q_lane_f32(&outV->z, mValue, 2);
784
- #else
785
- outV->x = mF32[0];
786
- outV->y = mF32[1];
787
- outV->z = mF32[2];
788
- #endif
789
- }
790
-
791
- UVec4 Vec3::ToInt() const
792
- {
793
- #if defined(JPH_USE_SSE)
794
- return _mm_cvttps_epi32(mValue);
795
- #elif defined(JPH_USE_NEON)
796
- return vcvtq_u32_f32(mValue);
797
- #else
798
- return UVec4(uint32(mF32[0]), uint32(mF32[1]), uint32(mF32[2]), uint32(mF32[3]));
799
- #endif
800
- }
801
-
802
- UVec4 Vec3::ReinterpretAsInt() const
803
- {
804
- #if defined(JPH_USE_SSE)
805
- return UVec4(_mm_castps_si128(mValue));
806
- #elif defined(JPH_USE_NEON)
807
- return vreinterpretq_u32_f32(mValue);
808
- #else
809
- return *reinterpret_cast<const UVec4 *>(this);
810
- #endif
811
- }
812
-
813
- float Vec3::ReduceMin() const
814
- {
815
- Vec3 v = sMin(mValue, Swizzle<SWIZZLE_Y, SWIZZLE_UNUSED, SWIZZLE_Z>());
816
- v = sMin(v, v.Swizzle<SWIZZLE_Z, SWIZZLE_UNUSED, SWIZZLE_UNUSED>());
817
- return v.GetX();
818
- }
819
-
820
- float Vec3::ReduceMax() const
821
- {
822
- Vec3 v = sMax(mValue, Swizzle<SWIZZLE_Y, SWIZZLE_UNUSED, SWIZZLE_Z>());
823
- v = sMax(v, v.Swizzle<SWIZZLE_Z, SWIZZLE_UNUSED, SWIZZLE_UNUSED>());
824
- return v.GetX();
825
- }
826
-
827
- Vec3 Vec3::GetNormalizedPerpendicular() const
828
- {
829
- if (abs(mF32[0]) > abs(mF32[1]))
830
- {
831
- float len = sqrt(mF32[0] * mF32[0] + mF32[2] * mF32[2]);
832
- return Vec3(mF32[2], 0.0f, -mF32[0]) / len;
833
- }
834
- else
835
- {
836
- float len = sqrt(mF32[1] * mF32[1] + mF32[2] * mF32[2]);
837
- return Vec3(0.0f, mF32[2], -mF32[1]) / len;
838
- }
839
- }
840
-
841
- Vec3 Vec3::GetSign() const
842
- {
843
- #if defined(JPH_USE_AVX512)
844
- return _mm_fixupimm_ps(mValue, mValue, _mm_set1_epi32(0xA9A90A00), 0);
845
- #elif defined(JPH_USE_SSE)
846
- Type minus_one = _mm_set1_ps(-1.0f);
847
- Type one = _mm_set1_ps(1.0f);
848
- return _mm_or_ps(_mm_and_ps(mValue, minus_one), one);
849
- #elif defined(JPH_USE_NEON)
850
- Type minus_one = vdupq_n_f32(-1.0f);
851
- Type one = vdupq_n_f32(1.0f);
852
- return vreinterpretq_f32_u32(vorrq_u32(vandq_u32(vreinterpretq_u32_f32(mValue), vreinterpretq_u32_f32(minus_one)), vreinterpretq_u32_f32(one)));
853
- #else
854
- return Vec3(std::signbit(mF32[0])? -1.0f : 1.0f,
855
- std::signbit(mF32[1])? -1.0f : 1.0f,
856
- std::signbit(mF32[2])? -1.0f : 1.0f);
857
- #endif
858
- }
859
-
860
- template <int X, int Y, int Z>
861
- JPH_INLINE Vec3 Vec3::FlipSign() const
862
- {
863
- static_assert(X == 1 || X == -1, "X must be 1 or -1");
864
- static_assert(Y == 1 || Y == -1, "Y must be 1 or -1");
865
- static_assert(Z == 1 || Z == -1, "Z must be 1 or -1");
866
- return Vec3::sXor(*this, Vec3(X > 0? 0.0f : -0.0f, Y > 0? 0.0f : -0.0f, Z > 0? 0.0f : -0.0f));
867
- }
868
-
869
- uint32 Vec3::CompressUnitVector() const
870
- {
871
- constexpr float cOneOverSqrt2 = 0.70710678f;
872
- constexpr uint cNumBits = 14;
873
- constexpr uint cMask = (1 << cNumBits) - 1;
874
- constexpr uint cMaxValue = cMask - 1; // Need odd number of buckets to quantize to or else we can't encode 0
875
- constexpr float cScale = float(cMaxValue) / (2.0f * cOneOverSqrt2);
876
-
877
- // Store sign bit
878
- Vec3 v = *this;
879
- uint32 max_element = v.Abs().GetHighestComponentIndex();
880
- uint32 value = 0;
881
- if (v[max_element] < 0.0f)
882
- {
883
- value = 0x80000000u;
884
- v = -v;
885
- }
886
-
887
- // Store highest component
888
- value |= max_element << 29;
889
-
890
- // Store the other two components in a compressed format
891
- UVec4 compressed = Vec3::sClamp((v + Vec3::sReplicate(cOneOverSqrt2)) * cScale + Vec3::sReplicate(0.5f), Vec3::sZero(), Vec3::sReplicate(cMaxValue)).ToInt();
892
- switch (max_element)
893
- {
894
- case 0:
895
- compressed = compressed.Swizzle<SWIZZLE_Y, SWIZZLE_Z, SWIZZLE_UNUSED, SWIZZLE_UNUSED>();
896
- break;
897
-
898
- case 1:
899
- compressed = compressed.Swizzle<SWIZZLE_X, SWIZZLE_Z, SWIZZLE_UNUSED, SWIZZLE_UNUSED>();
900
- break;
901
- }
902
-
903
- value |= compressed.GetX();
904
- value |= compressed.GetY() << cNumBits;
905
- return value;
906
- }
907
-
908
- Vec3 Vec3::sDecompressUnitVector(uint32 inValue)
909
- {
910
- constexpr float cOneOverSqrt2 = 0.70710678f;
911
- constexpr uint cNumBits = 14;
912
- constexpr uint cMask = (1u << cNumBits) - 1;
913
- constexpr uint cMaxValue = cMask - 1; // Need odd number of buckets to quantize to or else we can't encode 0
914
- constexpr float cScale = 2.0f * cOneOverSqrt2 / float(cMaxValue);
915
-
916
- // Restore two components
917
- Vec3 v = Vec3(UVec4(inValue & cMask, (inValue >> cNumBits) & cMask, 0, 0).ToFloat()) * cScale - Vec3(cOneOverSqrt2, cOneOverSqrt2, 0.0f);
918
- JPH_ASSERT(v.GetZ() == 0.0f);
919
-
920
- // Restore the highest component
921
- v.SetZ(sqrt(max(1.0f - v.LengthSq(), 0.0f)));
922
-
923
- // Extract sign
924
- if ((inValue & 0x80000000u) != 0)
925
- v = -v;
926
-
927
- // Swizzle the components in place
928
- switch ((inValue >> 29) & 3)
929
- {
930
- case 0:
931
- v = v.Swizzle<SWIZZLE_Z, SWIZZLE_X, SWIZZLE_Y>();
932
- break;
933
-
934
- case 1:
935
- v = v.Swizzle<SWIZZLE_X, SWIZZLE_Z, SWIZZLE_Y>();
936
- break;
937
- }
938
-
939
- return v;
940
- }
941
-
942
- JPH_NAMESPACE_END