Minie v8 physics libraries

A new version of the Minie physics library was released last night (14 February).

  • There are some API changes, but they’re unlikely to impact your applications. See the release notes for details.

  • The “+big3” build flavor has been replaced by a “+big4” flavor which supports the four 64-bit desktop platforms: Linux64, MacOSX64, MacOSX_ARM64, and Windows64. (Other build flavors are unaffected by this change.)

  • The CharacterControl.onGround() bug reported last month by @SrGnis is fixed in v8.0.0 .

  • The code to generate JME meshes from collision shapes was overhauled to make it more efficient. Previously mesh triangles were copied from native Bullet one vertex at a time, after which vertices were re-indexed by Java code. The new approach reduces the number of JNI calls and leverages any indices generated by native code.

For Gradle projects, the upgrade procedure is straightforward. Here is a typical buildscript:

repositories {
    mavenCentral()
}
dependencies {
    implementation 'com.github.stephengold:Minie:8.0.0'
}

Version 8.0.0 introduces an exciting feature: custom collision shapes. (This is a feature of jme3-jbullet that Minie previously lacked.) By extending the new CustomConvexShape class, you can define collision shapes in Java (or another JVM language).

Your code defines:

  • where the shape’s surface lies (by calculating the support location for any given normal direction),
  • the shape’s moment of inertia, and
  • how scalable the shape is.

This technique allows you to simulate some objects that the 17 pre-defined collision shapes don’t handle well. A hemisphere, for instance, might be approximated using HullCollisionShape. But without a large number of vertices, it wouldn’t roll properly on its curved side. (For performance and stability, a HullCollisionShape shouldn’t have more than 100 vertices.)

Sample code is provided here.

CustomConvex
A couple caveats:

  • only convex shapes (no indented shapes, nor shapes with holes)
  • performance is expected to be poorer than the standard shapes (which are implemented in native code)

If specific custom shapes prove popular, they can be re-implemented in native code for a future Minie release. So one might regard custom shapes as a prototyping tool.

18 Likes

Another great step forward for Minie! Thank you @sgold for all your work.

3 Likes

After almost 3 months of development, Minie v8.1.0 has been released. It depends on JME v3.6.1, and it includes:

  • fixes for issues 41 and 43, which affected the “Stranded” game
  • 2 new collision shapes (ConicalFrustum and SphericalSegment). These are fast, native-code replacements for the CustomFrustum and CustomSegment shapes.
  • new options for collisions, debug visualization, and serialization
  • much, much more

Issue 40, reported by @ndebruyn and @MGDSStudio in March, has been addressed by disabling contact filtering by default. However, I still occasionally see rigid bodies falling through terrain, so the issue remains open.

For Gradle projects, the upgrade procedure is straightforward. Here are fragments of a typical buildscript:

repositories {
    mavenCentral()
}
dependencies {
    implementation 'com.github.stephengold:Minie:8.1.0'
}

Further details are in the release notes. I’m also happy to answer Minie questions here in this Discourse Forum.

10 Likes

Minie v8.2.0 was released tonight. Not very different from v8.1.0, however this is the new recommended version for most physics applications.

repositories {
    mavenCentral()
}
dependencies {
    implementation "com.github.stephengold:Minie:8.2.0"
}

For the next release, I’m considering dropping support for x86_64 Androids and all 32-bit platforms other than Linux-on-ARM. So instead of 13 platforms, there would be only 7:

  • Android_ARM8
  • Linux64
  • Linux_ARM32hf
  • Linux_ARM64
  • MacOSX64
  • MacOSX_ARM64
  • Windows64

If that would cause problems for you, let me know.

7 Likes