Java-Gaming.org
Play Revenge of the Titans! The situation is critical. We need fancy commanders to defend Earth, the moon, Mars!
Featured games (78)
games approved by the League of Dukes
Games in Showcase (416)
games submitted by our members
Games in WIP (306)
games currently in development
News: Read the Java Gaming Resources, or peek at the official Java tutorials
 
    Home     Help   Search   Login   Register   
Pages: [1]
  ignore  |  Print  
  Phys2D FixedJoint unstable?  (Read 1929 times)
0 Members and 1 Guest are viewing this topic.
Offline Bananadine

Junior Newbie





« Posted 2008-05-20 05:48:18 »

Hi, I've recently tried Phys2D and found it generally good, and possibly applicable to the game I'm making.  However I'm troubled by an instability I've observed:  When I connect a chain of several objects via FixedJoints--say, four small boxes widely spaced in a U-shape, sort of like in Phys2D's Demo19--and drop the resulting shape onto a floor, it bounces and wiggles a bit, as one might expect, but the bouncing gradually becomes worse until the shapes simply fly out of sight.  Demo19 looks deceptively stable in comparison to this scenario, but I tried copying its setup and tweaking it a little, and I reproduced the same thing pretty easily.  Why does this happen?  Does Phys2D belong to some general class of physics engines of which this sort of instability is a basic feature?  Or is it conceivable that somebody could write a nicer, stabler FixedJoint without too much trouble?  My game is currently using ODE, which hasn't this problem...  though it is very unfortunately saddled with that nasty third dimension.  I don't know what people see in that thing.  Smiley

Special bonus question:  Cursory online research suggests that ODE is nondeterministic; experimentation suggests that Phys2D (and therefore perhaps Box2D et al) is deterministic.  Is this correct?  Is JOODE nondeterministic?  My game likes determinism!
Offline kevglass
« League of Dukes »

JGO Kernel


Medals: 54
Projects: 20


Mentally unstable, best avoided.


« Reply #1 - Posted 2008-05-20 08:26:46 »

Phys2D is deterministic.

However there are two reasons for the instability:

a) There are still a few bugs here and there which are generally improved by changing the world iterations and/or step size. However, this takes time and tuning

b) The simulation doesn't use continuous collision detection, as such it it accept some penetration and tries to resolve it. This is only an approximation and sometimes introduces error.

It's worth noting the new version of Box2D supports continuous collision detection and appears (to me at least) to be generally more stable. You can find it at http://www.jbox2d.org/

Kev

Offline irrisor

Junior Member





« Reply #2 - Posted 2008-05-20 09:14:55 »

Cursory online research suggests that ODE is nondeterministic
That's definately not the case: ODE is deterministic, as well. (At least in the common sense of "deterministic" in computer science... maybe you meant something else?)
Games published by our own members! Check 'em out!
Try the Free Demo of Droid Assault
Offline Bananadine

Junior Newbie





« Reply #3 - Posted 2008-05-20 20:47:00 »

I don't remember what determinism is in computer science.  Smiley  I meant that if you set up a physical scenario with ODE, and let it run twice, you'll get two different outcomes.  A box that falls on its corner near a ledge might topple off the ledge on one run, and then on the next run, tip back and settle on the ledge.  Like this guy says:  http://gamecreator.blogspot.com/2007/03/ode-determinism.html

Box2D does appear to be worth trying, so I'll move on to that and keep my Phys2D exploration on hold for now.  I know of JBox2D, and I would prefer to use that since it's pure Java--but maybe Java bindings to Box2D itself would also be worthwhile.  I don't immediately see any of those around though.
Offline irrisor

Junior Member





« Reply #4 - Posted 2008-05-21 09:41:58 »

uh, I couldn't believe it, because I thought I have read some posts on the ODE list about ODE being deterministic... but looking at the code it really uses random numbers Shocked
Pages: [1]
  ignore  |  Print  
 
 
You cannot reply to this message, because it is very, very old.

Play Revenge of the Titans! The situation is critical. We need fancy commanders to defend Earth, the moon, Mars!
 
Try the Free Demo of Revenge of the Titans

Add your game by posting it in the WIP section,
or publish it in Showcase.

The first screenshot will be displayed as a thumbnail.

The invasion has landed! On Mars! And you're there to beat 'em!
mrbenebob (14 views)
2013-06-19 14:55:23

BrassApparatus (22 views)
2013-06-19 08:52:37

NegativeZero (25 views)
2013-06-19 03:31:52

NegativeZero (28 views)
2013-06-19 03:24:09

Jesse_Attard (32 views)
2013-06-18 22:03:02

HeroesGraveDev (68 views)
2013-06-15 23:35:23

Vermeer (67 views)
2013-06-14 20:08:06

davedes (69 views)
2013-06-14 16:03:55

alaslipknot (61 views)
2013-06-13 07:56:31

Roquen (85 views)
2013-06-12 04:12:32
Smoothing Algorithm Question
by UprightPath
2013-05-28 02:58:26

Smoothing Algorithm Question
by UprightPath
2013-05-28 02:57:33

Complex number cookbook
by Roquen
2013-04-24 12:47:31

2D Dynamic Lighting
by Oskuro
2013-04-17 16:46:12

2D Dynamic Lighting
by Oskuro
2013-04-17 16:45:57

2D Dynamic Lighting
by Oskuro
2013-04-17 16:23:20

Noise (bandpassed white)
by Roquen
2013-04-05 17:36:01

Noise (bandpassed white)
by Roquen
2013-04-03 16:17:38
Powered by MySQL Powered by PHP Powered by SMF 1.1.18 | SMF © 2013, Simple Machines | Managed by Enhanced Four Valid XHTML 1.0! Valid CSS!