Changed: Libtoolize check has been put back into the bootstrap
[ode.git] / CHANGELOG.txt
blob8d1c2f6b56d03433565e1f909c36f72f54829f20
1 ODE CHANGELOG
2 -------------
4 the rules for this file:
5   * entries are sorted newest-first.
6   * summarize sets of changes - dont reproduce every CVS log comment here.
7   * don't ever delete anything.
8   * keep the format consistent (79 char width, M/D/Y date format).
10 ------------------------------------------------------------------------------
11 07/28/2020 Oleh Derevenko
12         * A threaded job data race fixed on job release (issue #70). 
13           The bug could cause writes to functions's stack area after 
14           the function returned and World simulation errors not being reported
15           with the function result if the simulation failed.
17 05/11/2020 Oleh Derevenko
18         * GIMPACT math macros were changed to use standard floating point math
19           rather than custom "optimized" implementations.
21 02/19/2020 Oleh Derevenko
22         * libCCD configuration description strings have been added for 
23           use with dGetConfiguration() and dCheckConfiguration().
25 03/06/2019 Oleh Derevenko
26         * dWorldAttachQuickStepDynamicIterationStatisticsSink public function 
27           was added to allow dynamic step count adjustment monitoring for
28           world instances.
30 02/21/2019 Oleh Derevenko
31         * Dynamic step count adjustment was implemented for dWorldQuickStep
32           with dWorldSetQuickStepDynamicIterationParameters and 
33           dWorldGetQuickStepDynamicIterationParameters new API functions
34           to control the feature.
35           The solver estimates per body resulting contact force maximal 
36           absolute adjustment value and may exit after fewer iterations if
37           the adjustments get smaller than the given threshold, or iterate 
38           longer if the adjustments are still significant after the default
39           iteration count is executed.
41 01/20/2019 Oleh Derevenko
42         * x86 targets have been changed to generate SSE2 code for calculations
43           by default with possibility to explicitly configure back for FPU.
45 11/12/2018 Oleh Derevenko
46         * The commentary from 11/05/2018 was wrong. The constraints were not
47           reset to their natural order and remained randomized.
48           The other thing that was missing was full contraint reorder without 
49           separation into independent and dependent ones. The algorithm doesn't
50           converge without it well.
52 11/10/2018 Oleh Derevenko
53         * An incorrect optimization to Jacobian Copy building code from #1938
54           that resulted in corrupt data in multi-threaded execution mode was 
55           fixed.
57 11/05/2018 Oleh Derevenko
58         * An unintended change from commit #1898 has been reverted.
59           The QuickStep used to solve with randomized constraint order 
60           each 8th iteration. The other iterations, the constraints 
61           were reset to their natural order, as generated, with the dependent
62           constraints gathered in reverse order at end (the reverse order is 
63           somehow important). With the commit #1898 the constraints were
64           randomly reordered each 8th iteration but then remained 
65           in that randomized order and only were re-randomized on subsequent
66           multiples of 8.
68 10/09/2017 Markus Rickert
69         * CMake support for project file generation has been added.
71 06/14/2017 Oleh Derevenko
72         * dxHashSpace::collide() has been changed to fault host program 
73           if scene gets too large and causes integer overflow.
75 06/06/2017 Oleh Derevenko
76         * Memory and pointer size integer type use has been changed so that 
77           internal typedefs are used instead of "_t" suffixed types.
79 05/09/2017 Oleh Derevenko
80         * Introduction of cooperative algorithms API. 
81           L*D*LT cooperative factorization and linear equation system 
82           cooperative solving have been implemented.
83         * AtomicReadReorderBarrier, AtomicStore, AtomicStorePointer functions 
84           have been added and some atomic function implementations have been 
85           improved in OU.
87 02/20/2017 Oleh Derevenko
88         * Project generation options have been changed to have built-in
89           multithreaded threading implementation enabled by default.
91 02/19/2017 Oleh Derevenko
92         * dWorldStep threaded implementation has been extended to the final 
93           steps of constraint force applications and body position updates
94           after the LCP solving. Note that body callbacks (if set) may be
95           called from multiple threads if threaded execution is enabled.
96         * OU atomicord32 type has been fixed to be unsigned on all supported
97           platforms.
99 01/09/2017 Oleh Derevenko
100         * dGeomTriMeshDataPreprocess2() public function has been added to 
101           replace dGeomTriMeshDataPreprocess(). Face angles pre-computation
102           for triangle meshes has been implemented.
104 11/13/2016 Oleh Derevenko
105         * dGeomTriMeshDataGetBuff and dGeomTriMeshDataSetBuff have been marked 
106           deprecated and their functionality implemented via 
107           dGeomTriMeshDataGet and dGeomTriMeshDataSet. Extra function variant
108           dGeomTriMeshDataGet2() has been added to allow returning data size.
110 11/07/2016 Oleh Derevenko
111         * The implementation of OPCODE TriMesh data pre-processing 
112           (dGeomTriMeshDataPreprocess()) has been optimized to only contain
113           a sort and a single pass over edges (used to be a sort and O(N^2)).
115 10/29/2016 Oleh Derevenko
116         * dGeomTriMeshDataPreprocess() public function has been changed to 
117           return a boolean status (it can fail in low memory conditions).
119 07/10/2016 Oleh Derevenko
120         * The correct handling of dJOINT_REVERSE mode for AngularMotor Joint 
121           implemented (issue #37).
123 06/29/2016 Oleh Derevenko
124         * A bug fixed with HashSpace calling big boxes collision twice 
125           (both straight and reverse geometries order) since revision #1831.
127 06/03/2016 Oleh Derevenko
128         * dJointSetHinge2Axes public function has been added and 
129           dJointSetHinge2Axis1/2 have been marked deprecated due to being 
130           unsafe.
132 05/13/2016 Oleh Derevenko
133         * ICE Container class allocation strategy fixed to avoid reserving 
134           excess memory with large collections.
136 05/10/2016 Oleh Derevenko
137         * dSafeNormalize3 and dSafeNormalize4 functions changed to leave the
138           parameter intact instead of replacing it with the X-axis unit in case 
139           of fault.
141 04/12/2016 Oleh Derevenko
142         * A function to create a self-threaded threading implementation object
143           has been moved back to public headers as there could be a use for it
144           while running several worlds in parallel threads.
146 01/09/2016 Oleh Derevenko
147         * Hinge2 joint corected to avoid faulting asserts when the axes get 
148           temporarily invalid during assignments (suggested by David Mansolino)
150 01/03/2016 Oleh Derevenko
151         * An invalid memory access fixed in dxSAPSpace::BoxPruning() in case
152           if there were NaN values in AABBs to be sorted.
154 12/25/2015 Oleh Derevenko
155         * Unexpected joint mode assignment (instead of comparison) fixed within
156           an dUASSERT in dJointSetTransmissionAxis2() of transmission joint
158 11/28/2015 Oleh Derevenko
159         * Convex-Trimesh collider added (libccd+GIMPACT only)(by Piotr Piastucki)
160         * dCreateConvex() and dGeomSetConvex() public APIs changed to expect 
161           their parameter arrays as const pointers
163 11/01/2015 Oleh Derevenko
164         * OPCODE mesh colliders' input coordinates have been offset to  
165           mesh-relative frames to decrease potential computational errors
166           (suggested by luckytrashsc2@g***l.com)
168 08/05/2015 Oleh Derevenko
169         * Implemented change to return highest depth contacts subset for GIMPACT 
170           in cases if contacts count exceeds requested maximum (as suggested in 
171           the issue #36 by Piotr Piastucki)
173 11/17/2014 Daniel K. O.
174         * Added support for using libccd from the system (if found via
175           pkg-config)
177 11/10/2014 Oleh Derevenko
178         * Floating point division by zero in capsule-ray collision routine 
179           in case if the ray axis was parallel the cylinder and the ray started
180           from within it fixed (issue #26)
182 11/08/2014 Oleh Derevenko
183         * Threading support has been extended to complete implementation 
184           of QuickStep
186 10/29/2014 Daniel K. O.
187         * Added dJointSetDBallDistance
189 10/19/2014 Oleh Derevenko
190         * Built-in threading implementation compilation fixed for OSX
191           (clock_gettime() is missing from the system - reported by Bram)
193 08/10/2014 Oleh Derevenko
194         * Declarations of dWorld[Get/Set]AutoDisableLinearAverageThreshold and
195           dWorld[Get/Set]AutoDisableAngularAverageThreshold have been removed 
196           from public headers (were orphaned since rev.1052)
198 07/16/2014 Oleh Derevenko
199         * Two fixes by Francesco Cat applied (fixes for mistakes made during
200           code style improvements in the past)
201                  
202 02/27/14 Daniel K. O.
203         * Added dODE_VERSION macro to public headers (issue #24).
205 02/11/14 Daniel K. O.
206         * Added dJointGetHinge2Angle2 (issue #12).
208 02/07/14 Daniel K. O.
209         * Added dWorldSetData/dWorldGetData (issue #21).
211 01/31/14 Daniel K. O.
212         * Applied patch #185: Stable, implicit gyroscopic forces.
214 01/27/14 Daniel K. O.
215         * Fixed cylinder AABB computation.
217 01/25/14 Daniel K. O.
218         * Removed ALLOCA calls from dHashSpace; it should not depend
219           on stack size limits anymore.
221 12/06/13 Daniel K. O.
222         * Applied patch #181: fix some bugs in AMotor joint.
223         * Applied patch #186: fix some bugs in PU joint.
224         * Applied patch #182: Transmission joint.
225         * Applied patch #184: implement rolling friction for contacts.
227 08/08/13 Oleh Derevenko
228         * Joint feedback forces application fixed in QuickStep implementation
229           (was broken since revision #1919 in old repository (#1927 in new one))
231 08/04/13 Oleh Derevenko
232         * Bugfix #89 by Luc applied (dJointAddSliderForce() adds a zero force
233           when the parent body is NULL) 
235 05/18/13 Oleh Derevenko
236         * OU library has been included in ODE at revision #46 instead of  
237           being used as an external link due to difficulties using external 
238           references with new protocol used for storage at SF.
240 03/03/13 Oleh Derevenko
241         * Fixed issue with "findex==-1" constraints being intermixed with 
242           "findex!=-1" ones during constraints random reordering in QuickStep.
244 02/03/13 Oleh Derevenko
245         * [u]int[8/16/32] renamed to contain "d" prefix so that global namespace
246           was not polluted with these names unconditionally. 
247           If your project depended on these types other than just for passing 
248           parameters to ODE calls, add similar typedefs for yourself in some 
249           of your project's global headers.
251 01/02/13 Oleh Derevenko
252         * Applied patch #183 by Joseph Cooper (complementary matrix 
253           calculation fix).
255 12/28/12 Oleh Derevenko
256         * A bug with heightfield data assigned to a wrong field in 
257           dGeomHeightfieldSetHeightfieldData fixed (bug report #88 by Luc).
259 12/18/12 Oleh Derevenko
260         * Fixed issue with some kinds of joints (Ball, DBall, DHinge, Fixed)
261           might overwrite world ERP value with their custom ERP during 
262           getInfo2() call and that inappropriate value would then be passed 
263           to subsequent joints in solver instead of world ERP.
265 12/01/12 Oleh Derevenko
266         * Fixed issues reported in patches #151 and #22 (collisions with
267           SAPSpace and QuadTreeSpace might not work because geometries list
268           was misused in them).
269         * Applied patch #160 "IsPointInPolygon in convex.cpp returns wrong 
270           results" (by Janis Rucis)
272 11/25/12 Oleh Derevenko
273         * Configuration option --disable-threading-intf added 
274           (--no-threading-intf for Windows/Premake). This allows disabling
275           threading interface support (external implementations may not be 
276           assigned) but eliminates dependency on OU and use of atomics in 
277           steppers.
279 11/05/12 Oleh Derevenko
280         * Fixed zero comparisons in OPCODE to use relative error instead of
281           absolute epsilon value (found by Bill Sellers)
283 06/08/12 Daniel K. O.
284         * Removed the need for defining dSINGLE/dDOUBLE; this is stored now in
285           the generated ode/precision.h header.
286         * Some code cleanup to get rid of GCC warnings.
288 05/30/12 Daniel K. O.
289         * Made drawstuff draw shadows for lines.
290         * Fixed dhinge's last constraint to properly handle rotations.
292 05/03/12 Daniel K. O.
293         * Added two new joints: Double Ball and Double Hinge.
295 04/22/12 Daniel K. O.
296         * Fixed plane2d joint: uninitialized variables (reported by Dimitris
297           Papavasiliou)
299 04/14/12 Oleh Derevenko
300         * Assertion checking macros moved into library private headers.
302 04/13/12 Daniel K. O.
303         * Applied patch from bug  #3431829 - better handling of capsule-box with
304           deep penetrations.
305         * Fixed zero-mu issues: now either mu or mu2 can be set to zero.
307 03/17/12 Oleh Derevenko
308         * Threaded execution support interface added. Optional built-in threading
309           implementation added.
310           Internal threading implementation is excluded by default and to be used, 
311           it must be enabled with configure/premake.
312           At present, if threading interface is assigned to a world, island 
313           selection and stepping is performed in multiple threads (one thread per 
314           island).
316 03/12/12 Oleh Derevenko
317         * PURE_INLINE macro renamed to ODE_PURE_INLINE and definition of 
318           dNextAfter()/dCopySign() corrected to avoid creating conflicts with 
319           other libraries.
321 02/03/12 Oleh Derevenko
322         * Assertion checking macros moved from common.h to error.h
324 12/18/11 Oleh Derevenko
325         * dIVERIFY macro added (same as dIASSERT in debug mode but evaluates its
326           expression in release mode) to be used to assert variable value 
327           which is not used further in text while avoiding compiler warning.
328         * dICHECK macro added (same as dIASSERT but evaluates its expression and 
329           raises assertion fault regardless of compilation mode) to be used to
330           generate a fault in cases when error is very unlikely but must be 
331           handled and handling is very troublesome (e.g. failure to lock a mutex
332           due to lack of resources).
334 12/07/11 Oleh Derevenko
335         * Partially fixed size_t to integer conversion warnings
336         * Fixed type signedness and added casts to size_t wherever necessary 
337           in Step/QuickStep
339 11/04/11 Daniel K. O.
340         * Applied patch #3429454 - fix compilation on some platforms.
342 10/28/11 Daniel K. O.
343         * Fixed a box-capsule bug: more reasonable normal for deep penetrations
344           (contributed by Georg Martius.)
346 10/27/11 Daniel K. O.
347         * Disabled merging of contacts for trimesh-sphere by default.
348         * Added new demo: demo_tracks.
350 10/17/11 Daniel K. O.
351         * Added python bindings, contributed by Gideon Klompje.
352         * Updated some build scripts.
353         * Changed spheres distribution in demo_space_stress.
355 05/17/11 Oleh Derevenko
356         * A typo in step.cpp fixed (assignment operator in a conditional 
357           instead of comparison) (reported by Bram Stolk)
359 01/29/11 Oleh Derevenko
360         * Heightfield zone boundaries calculation code fixed to also consider
361           whole next cell after the AABB if the AABB ends exactly at the cell
362           boundary.
364 01/23/11 Daniel K. O.
365         * Applied patch from Daniel Fiser, add libccd collider for
366           box-cylinder.
368 01/20/11 Daniel K. O.
369         * Applied patch from Daniel Fiser, fix infinite loop in libccd caused
370           by numerical problems.
372 01/06/11 Daniel K. O.
373         * Applied patch from Daniel Fiser, efficient libccd tests when using
374           CONTACTS_UNIMPORTANT.
376 12/17/10 Daniel K. O.
377         * Applied patches from Daniel Fiser for new colliders based on libccd.
379 11/08/10 Daniel K. O.
380         * Applied patches from Daniel Fiser to incorporate libccd for
381           Cylinder-Cylinder collision tests.
383 08/21/10 Oleh Derevenko
384         * Fix applied to dxReallocateTemporayWorldProcessContext() to remove typo 
385           which caused segmentation fault (by Kyle McKay).
386           dTestSolveLCP() fixed to avoid exceeding allocated memory pool 
387           (by Kyle McKay).
389 07/19/10 Oleh Derevenko
390         * Patch applied (#3030783) to fix drawstuff dimensions being ignored
391           in OSX GLUT port (by Danny Price).
393          Daniel K. O.
394         * Applied patch #2991622: dGeomGetRelPointPos, dGeomGetPosRelPoint,
395           dGeomVectorToWorld, and dGeomVectorFromWorld.
397 07/16/10 Daniel K. O.
398         * Fixed bug #2937076: don't try to build demos if drawstuff is disabled.
400 05/02/10 Oleh Derevenko
401         * Missing extern "C" wrapper has been added to include/ode/export-dif.h
402           (reported by Danny Price). The change affects dWorldExportDIF() public 
403           function.
405 05/02/10 Oleh Derevenko
406         * Patch applied (#2995450) to generate up to four contacts for box-
407           plane collision test (by alexdu) and fix contact depths.
409 05/02/10 Oleh Derevenko
410         * dGeomLowLevelControl function added with ability to change/query OPCODE 
411           trimesh-sphere contact merging behavior at runtime.
413 02/18/10 Daniel K. O.
414         * Fixed bug affecting disabled joints and dWorldStep.
416 01/16/10 Oleh Derevenko
417         * Patch applied (#2931174) to make demos work for recent MacOS.
418         * Patch applied (#2931177) to fix the demos' framerate on X11.
420 12/20/09 Oleh Derevenko
421         * QuadTreeSpace implementation corrected to avoid object-block relation 
422           ambiguity due to numeric errors.
424 12/04/09 Oleh Derevenko
425         * odecpp classes changed to be inheritable and easily expandable
427 11/29/09 Oleh Derevenko
428         * Improvement for trimesh-plane collision (also used in trimesh-heightfield)
429           to exclude mesh vertices that have already generated contacts from further
430           examination and contact generation in other triangles (suggested by LR).
432 10/25/09 Oleh Derevenko
433         * Macros changed to static inline functions in odemath.h and related files.
434           Some code duplication has been eliminated across the files.
436         * Fixed handling of --disable-asserts and --enable-double-precision 
437           (absence of --enable-double-precision) in configure script. The script
438           was not appending compiler defines correctly.
440         * dWorldStep implementation changed to remove allocation on stack. 
441           dUSE_MALLOC_FOR_ALLOCA define has been removed as well as corresponding
442           configuration parameter. Also dMemoryFlag public variable has been removed.
443           (look for presence of ODE_EXT_malloc_not_alloca configuration string if
444           your application is dependent on that variable).
446 09/05/09 Oleh Derevenko
447         * dWorldStepFast1 API removed along with dWorld[Get/Set]AutoEnableDepthSF1
449 08/29/09 Oleh Derevenko
450         * Fixed uninitialized floating point array used in computations.
452 08/12/09 Oleh Derevenko
453         * A typo fixed in dGeomCopyOffsetRotation() (final_posr was used instead 
454           of offset_posr). Reported by Tilmann.
456 08/11/09 Daniel K. O.
457         * Made sure neither dSINGLE or dDOUBLE is defined by default; the user
458           should always explicitly specify the precision.
460 06/27/09 Oleh Derevenko
461         * New functions have been added:
462            - dWorldUseSharedWorkingMemory
463            - dWorldCleanupWorkingMemory
464            - dWorldSetStepMemoryReservationPolicy
465            - dWorldSetStepMemoryManager
466                 
467 06/25/09 Remi Ricard (papaDoc)
468         * Add limit to the to the second axis of the universal joint
469          for the pu joint.
471 06/14/09 Oleh Derevenko
472                 * dWorldQuickStep re-implemented to avoid memory allocation on stack.
473                   Also several optimizations have been made to decrease memory 
474                   requirements and optimize algorithm implementation of dWorldQuickStep.
475                   dWorldStep still remains with old memory allocation however new APIs
476                   mentioned below are fully functional for it.
477                   Both dWorldStep and dWorldQuickStep have been changed to return boolean
478                   success status.
480                 * dInitODE2() changed to automatically call 
481                   AllocateODEDataForThread(dAllocateFlagBasicData) after library 
482                   initialization as this is a required initialization minimum that
483                   must always be performed anyway.
485 06/05/09 Daniel K. O.
486          * Removed aliasing issues from OPCODE/Ice, plus some other warnings.
487            Now it builds on gcc 4.3.2 with '-Wall -Werror -O3".
489 05/30/09 Oleh Derevenko
490          * A minor memory usage optimization for QuickStep.
492 05/24/09 Daniel K. O.
493          * Made the new trimesh collider the default.
494          * Added a "-texturepath" option to drawstuff.
496 05/18/09 Oleh Derevenko
497         * Heightfield rotation fixed to avoid NaNs while rotating infinite
498           MIN/MAX heights.
500 05/03/09 Oleh Derevenko
501         * Incorrect parameter order fixed on contact merging in Sphere-Trimesh
502           collisions. The bug resulted in merged contact remaining with normal
503           of first contact found. Thanks to Dimitris Papavasiliou for reporting.
505 04/23/09 Daniel K. O.
506         * Fixed bug #2685170: use the C99 __func__ instead of __FUNCTION__ when
507           a C99 implementation is available.
509 04/07/09 Remi Ricard (papaDoc)
510         * Remove unused code in demo_joints.cpp, reported by Tilmann.
512 04/07/09 Remi Ricard (papaDoc)
513         * Fix bug in collision categories in demo_jointPU, reported by Tilmann
515 03/14/09 Oleh Derevenko
516         * A possibility to initialize/close ODE multiple times recursively has 
517           been added.
518           Also, now a call to dSpaceSetManualCleanup() is required for each 
519           space right after creation if ODE has been initialized in thread data
520           manual cleanup mode.
521            
522 03/07/09 Oleh Derevenko
523         * Thread local data has been cleaned up from OPCODE and OdeTls as it is
524           not used (OPC_SweepAndPrune.* and OPC_BoxPruning.* have been removed
525           - rebuilding project files is necessary).
527 02/07/09 Daniel K. O.
528         * New house of cards demo, which stresses the friction handling stability.
530 01/29/09 Remi Ricard (papaDoc)
531         * Fix bug: Fix problem when attaching no body to a joint. Before calling
532           setRelativeValues a check is made for bodies.
533         * Add unittest
535 01/28/09 Daniel K. O.
536         * Applied patch #2538046: Heightfield AABB bounds patch.
538 01/23/09 Remi Ricard (papaDoc)
539          * Add new function dJointSetUniversalAxis1Offset and dJointSetUniversalAxis2Offset
540          * Add unittest for those funcitons.
542 01/23/09 Remi Ricard (papaDoc)
543          * Fix problem with dJointGetUniversalAngle2 when the joint is attached to
544            only a body 2. The sign was inverted.
545          * Add unit test to verify for this problem
547 01/21/09 Remi Ricard (papaDoc)
548          * Fix bug reported by Tilman: dxJointPU::getInfo1 was setting twice the
549            limit of limot1 to zero and not limot2
551 01/17/09 Daniel K. O.
552         * Fixed a bug in dSpaceCollide2: if both geoms are not in spaces they would
553           not have valid AABBs.
555 12/20/08 Daniel K. O.
556         * New functions: dJointEnable, dJointDisable, dJointIsEnabled
557           (patch #2454764).
559 12/19/08 Daniel K. O.
560         * Removed inline asm statements that break builds on 64-bit VC++.
562 12/09/08 Daniel K. O.
563         * Applied patch #2381592, which adds support for Kinematic Bodies.
565 12/06/08 Oleh Derevenko
567        * Applied a patch by Martijn Buijs to make GIMPACT trimesh-ray collisions to
568          be consistent with those in OPCODE.
569        * Swapped geometries returned in contacts for OPCODE Trimesh-Plane collisions
570          as they were returned in unnatural order being different from that in GIMPACT
571        * Applied a patch by Martijn Buijs to make side1, side2 fields of contact 
572          structure be always initialized, either with -1 for non-trmesh geometries
573          or with triangle index for trimeshes. These fields were only assigned for
574          trimesh-trimesh collisions before.
575        * dGeomTriMeshSetTriMergeCallback/dGeomTriMeshGetTriMergeCallback API added
576          to set/get user defined callback procedure for trimeshes that would be 
577          invoked when contacts are merged to let user code accumulate attributes of
578          original contact triangles and generate a fake index by which it would 
579          later be able to determine those attributes. If the callback is not 
580          assigned (the default) -1 is generated as triangle index for merged 
581          contacts (there was an index of first of merged triangles before!!!).
582          The callback is currently used within OPCODE trimesh-sphere and OPCODE
583          new trimesh-trimesh collisions.
585 11/20/08 Remi Ricard (papaDoc)
586        * Fix problem with dJointGetPUPosition and
587          dJointGetPUPositionRate when the joint is attached to only
588          a body 2. The sign was inverted.
589        * Fix bug: When a pu joint had only one body attached to position 2,
590          dJointAttach(jId, 0, bId). The body was not push in the right direction to
591          move back between the limits.
592        * Add unit test to check the above problem
593        * Add the function void dJointSetPUAnchorOffset
594        * Make the function void dJointSetPUAnchorDelta deprecated
596 11/19/08 Remi Ricard (papaDoc)
597        * Fix bug: When a pr joint had only one body attached to position 2,
598          dJointAttach(jId, 0, bId). The body was not push in the right direction to
599          move back between the limits.
600        * Add unit test to check the above problem
602 11/19/08 Remi Ricard (papaDoc)
603         * Fix problem with dJointGetPRPosition and
604           dJointGetPRPositionRate when the joint is attached to only
605           a body 2. The sign was inverted.
606         * Add unit test to check the above problem
607         * Increase the tolerance to remove failure in unit test
608         * Remove compilation warning in unit test with the use of REAL()
610 11/18/08 Remi Ricard (papaDoc)
611        * Fix bug: When a piston joint had only one body attached to position 2,
612          dJointAttach(jId, 0, bId). The body was not push in the right direction to
613          move back between the limits.
614        * Add more functionality to demo_piston.cpp
615        * Run astyle on modified files.
617 11/18/08 Remi Ricard (papaDoc)
618         * Fix bug: When a slider joint had only one body attached to position 2,
619          dJointAttach(jId, 0, bId). The body was not push in the right direction to
620          move back between the limits.
622 10/29/08 Oleh Derevenko
624         * Premake scripts changed to only include chosen collision library
625           sources in project on Windows. --all-collis-libs premake option 
626           added to allow inclusion of all collision library sources into the 
627           project
629 10/15/08 Remi Ricard (papaDoc)
630         * Applying patch #2158425 64-bit GIMPACT provided by Mark
631           William. This patch enable GIMPACT to works on 64-bit machine.
633 10/15/08 Remi Ricard (papaDoc)
634         * Add function dJointGetPRAngle and dJointGetPRAngleRate
636 10/15/08 Remi Ricard (papaDoc)
637         * Enable the motor on the rotoide part of the PR joint
639 10/15/08 Remi Ricard (papaDoc)
640         * Add unit test to check if using directly a joint
641           or using after setting with default values is the same.
642         * Add function setRelativeValues called in dJointAttach for
643           all joints.
645 10/10/08 Remi Ricard (papaDoc)
646         * Fix bug in dJointGetPUAxis2. The axis was not multiplied with the
647           the rotation matrix of the good body.
648         * Fix bug if there is only one body on the PU joint the axis returned
649           was not the right one.
650         * Add unit test to verify previous bug.
652 10/03/08 Rodrigo Hernandez (Kwizatz)
653         * Added Blender script to create ODE convex geoms under tools.
655 10/01/08 Rodrigo Hernandez (Kwizatz)
656         * Convex-Convex collision detection code is finally stable.
658 08/31/08 Daniel K. O.
659         * Applied patch 2080674: Improved dBodySetRotation; now exact rotation
660           matrices are preserved until the next simulation step.
662 08/07/08 Daniel K. O.
663         * Fixed strict aliasing issue that was breaking the new trimesh collider.
665 07/24/08 Daniel K. O.
666         * New functions: dBodyGetGyroscopicMode and dBodySetGyroscopicMode
667           (patch #2019242).
669 07/15/08  Remi Ricard (papaDoc)
670         * Add a new define ODE_API_DEPRECATED to mark function as deprecated
671           when necessary.
673 07/14/08 Remi Ricard (papaDoc)
674         * Finish adding patch 1336066: Joint feedback in quickstep by jsinecky
675         * demo_boxstack.cpp can now print joint feedback
677 07/11/08 Daniel K. O.
678         * Bumped version for 0.10.1
679         * Added proper usage of libtool's version info.
681 07/10/08 Remi Ricard (papaDoc)
682         * Add new function dJointSetPistonAnchorOffset
683         * Add unittest for the piston joint
684         * Fix problem with dJointGetPistonPosition and 
685           dJointGetPistonPositionRate when the joint is attached to only
686           a body 2. The sign was inverted.
688 07/09/08 Remi Ricard (papaDoc)
689         * Optimize function Multiply1_12q1 in quickstep
690           Patch proposed by Riemer v.d. Zee and modified by Patrick Baggett
692 07/08/08 Remi Ricard (papaDoc)
693         * Update the slider joint to have the same behavior as the other joint
694           when there is only a body2 attached to it.
695         * Update documentation for the slider joint.
696         * Remove warning by using REAL()
697         * Add new unittest for dJointGetSliderPositionRate
699 07/08/08 Remi Ricard (papaDoc)
700         * Update unittest for the slider.
701         * Rename the new function dJointSetHingeAxisDelta to 
702           dJointSetHingeAxisOffset. This remove will remove confusion with 
703           the old function dJointSetHingeAnchorDelta
704         * Update documentation for the Hinge unittest
705         * Remove warning by using REAL()
707 07/07/08 Daniel K. O.
708         * Max Correcting Vel doesn't affect bounciness, as before.
710 07/03/08 Remi Ricard (papaDoc)
711         * Add new function dJointSetHingeAxisDelta
712         * Add unittest for this new function
714 06/17/08 Remi Ricard (papaDoc)
716         *  Move the computation of the Relative Rotation for the slider joint
717            into a function.
718         * Add unittest for to check qrel 
720 06/17/08 Remi Ricard (papaDoc)
722        * Remove unused variables. 
723        * Remove a conversion warning between unsigned int and int
724         
725 06/17/08 Remi Ricard (papaDoc)
727         * Move the function hingeComputeRelativeRotation as a member of 
728           the hinge structure/class.
730 06/17/08 Remi Ricard (papaDoc)
732         *  Move the computation of the Relative Rotation for the fixed joint
733            into a function.
735 06/16/08 Remi Ricard (papaDoc)
737         * Add testunit for the dxJointFixed
739 06/04/08 Daniel K. O.
741         * Moved joints to ode/src/joints, converted them to true virtual
742           methods.
744 06/02/08 Daniel K. O.
746         * Added an Auto<T> template to step.cpp to handle memory deallocation.
748 05/09/08 Daniel K. O.
750         * Applied patch #1335202: Contact Joint Motion (with some corrections),
751           and added demo_motion.
753 05/01/08 Oleh Derevenko
755         * Memory leak in GIMPACT fixed (reported by Derek)
757 04/28/08 Oleh Derevenko
759         * Added possibility to collide a space of lower sublevel as a geometry
760           against another space of a higher level with dSpaceCollide2.
761           dSpaceSetSublevel/dSpaceGetSublevel are used for sublevel assignment/
762           retrieval.
764 04/27/08 Oleh Derevenko
766         * Fixed incorrect memory copying which could lead to memory corruption
767           in GIMPACT (luckily, in unused code)
768         * Fixed possible memory read beyond the end of allocated buffer along
769           with unnecessary extra memory copying in GIMPACT.
770         * Fixed buffer reserve being incorrectly reset to zero for bitsets 
771           what resulted in unnecessary memory reallocations in GIMPACT.
772         * Implemented support for ability to run collision detection from
773           multiple threads for separate spaces.
774            
775 04/14/08 Oleh Derevenko
777         * Fixed possible memory corruption in new trimesh-trimesh collider
778           in case if two degenerated triangles are checked against each other.
780 04/12/08 Oleh Derevenko
782         * Fixed sporadic assertion failure on vector normalization caused
783           by small triangles degenerating into segments during space 
784           transformations.
786 03/28/08 Remi
788         * Fix a bug in dJointXXXGetInfo. The value in limot.limit was not
789           always updated. (Ex: If hi and lo limit were changed). 
791 03/27/08 Remi
793         * Added a new Joint: Prismatic Universal (patch #1828454).
795          Daniel K. O.
797         * Fixed bug #1841309: collide2() method buggy.
799 03/18/08 Rodrigo
801         * New function: dVector4Copy.
803 03/14/08 david
805         * Added stub calls for trimesh functions.
806         * Applied patch #1914232: dGetConfiguration.
807         * Applied patch #1655333: Optimize the function dNormalize3.
808         * New function: dSetColliderOverride.
809         * New function: dCheckConfiguration.
810         
811          Daniel K. O.
813         * Disabled building shared library by default with autotools.
815 03/13/08 david
817         * New function: dJointGetNumBodies (patch #1901550).
818         * New function: dSpaceGetClass (patch #1901637).
819         * Applied patch #1901649: Add missing function in the export
821 03/12/08 Rodrigo
823         * Fixed drawstuff build issues on OSX.
825 01/12/08 Daniel K. O.
827         * Fixed a typedef bug in configure.in.
828         * Added dCylinder to the C++ wrappers.
829         * Applied patch 1851394: support for GIMPACT with double precision,
830           dCollide fix.
831         * Moved bunny geometry to bunny_geom.h.
833 12/11/07 Daniel K. O.
835         * Added damping and MaxAngularVel() functions.
836         * Const-correctness: added const qualifier to some dWorldGet and dBodyGet
837           functions.
838         * Updated the odecpp.h header.
840 12/07/07 Daniel K. O.
842         * Removed most of the compiler warnings from Drawstuff, ODE and
843           OPCODE
844         * Upgraded automake requirement to 1.10, and change some Makefile.am
846 12/06/07 Rodrigo
848         * Modified autotools to use libtool for
849           library generation and administration
850         * Removed release and debug flags for configure.in
851           CPPFLAGS, CFLAGS, CXXFLAGS should be set by the
852           user to their liking, respecting autotools policies.
854 11/30/07 Daniel K. O.
855         * Applied patch 1813079 (moved callback)
856         * Replaced moveAndRotateBody by dxStepBody in stepfast.cpp
858 11/10/07 david
860         * Added 'Sweep and Prune' collision space.
861         * New Piston joint type with demo, by Remi Ricard
862         * Added build option to use 16-bit indices for OPCODE trimesh
864 11/03/06 david
866         * Integrated Christoph Beyer's average based sampling system for body
867           disabling.
869 10/26/06 Francisco Leon
871         * Totally refactored trimesh collision system.
872           Using GIMPACT instead of OPCODE. Now works correctly, and faster.
873           Visit http://gimpact.sourceforge.net.
874           
875         * Finally, test_moving_trimesh.exe works nicely.   
876           
877         * Fixed autodisable system. Now is possible to set bigger sleeping 
878           threshold values and objects won't be sleeping on the air. They will
879           rest on the floor properly.
880                   
881         * dInitODE function added.
882         
883         * Is Obligatory to call dInitODE() at the beginning for initialize ODE,
884           and calling dCloseODE() when the program ends.
886 09/20/06 bram
888         * Fixed two bugs in cyl/plane collision test.
890 09/13/06 Remi
892         * New Rotoide - Prismatic joint type
893         * dJointGetUniversalAngles for efficient angle retrieval.
895 08/09/06 david
897         * Integrated plane2d joint type which constrains bodies to z == 0.
899 07/06/06 david
901         * Added heightfield primitive collision code. Simple test available in
902           ode/test/test_heightfield
904 04/03/06 rodrigo
906         * Added Convex primitive collision code,
907           currently only convex-sphere and convex-plane work
909 04/01/06 bram
911         * Added program to test trimesh vs sphere: ode/test/test_basket
913 03/20/06 jason379
915         * Added new autogenerated Visual Studio projects, with Premake scripts
917 03/17/06 bram
919         * Added plane/cyl intersection test
920         * Renamed CCylinder to Capsule
921         
922 02/04/06 gcarlton
924         * Added support for geom offsets.
926 10/26/05 rodrigo
928         * Removed LIBTOOL from autotools since it was not really required.
929         * Added a target to build ODE as a shared library, this shared
930           library gets build alongside the static one, no flags required.
932 10/24/05 tfautre
934         (Backported patches from STABLE branch, applied by Adam)
935         
936         * dRandInt changed for a non-double all-int version.
937         * mics minor fixes and improvements.
939 04/05/05 tfautre
941         * Fixed segmentation fault with OPCODE on 64 bits systems.
943 03/31/05 tfautre
945         * Fixed timer.cpp compiler error on x86-64 using GCC.
947 03/29/05 colin
949         * Added trimesh preprocessing to mark unneeded edges and verts.  Also
950           added support for preprocessed info to the ccylinder-trimesh
951           collider.
953 12/07/04 adam
955         * Important AMotors bugfix
957 09/22/04 jeff
959         * Assorted small bugfixes and tweaks for
960           trimesh_{box,ccylinder,trimesh} collisions
962 09/21/04 jeff
964         * added functions to joint.cpp to allow joint attachment to moving
965           geoms.
967         * added malloc-based memory allocation in step.cpp & lcp.cpp (turned
968           on with a #define switch in common.h)
969         
970 05/29/04 russ
972         * added joint feedback to the QuickStep solver
974 05/18/04 russ
976         * added warm starting to the QuickStep solver
978 05/18/04 russ
980         * added the QuickStep solver
981         
982         * added contact parameter functions.
984 05/05/04 adam
986         * use dRandInt instead of rand() in stepfast.
988 04/21/04 russ
990         * added auto-disable support from Aras Pranckevicius (with
991           modifications by russ). this useful feature can speed up
992           simulation significantly in some cases.
993         
994         * various internal tidyups.
996 04/20/04 russ
998         * changed the meaning of the 'index' argument to dJointGetBody():
999           it was the only remaining API function that does not respect
1000           dJOINT_REVERSE (spotted by Matthew D. Hancher).
1001         
1002         * updated the C++ headers: fixed two minor bugs and added
1003           support for dQuadTreeSpace, dRay, and the dGeom::getSpace() method
1004           (from Matthew D. Hancher).
1006 04/18/04 russ
1008         * changed the way that the dInfinity constant is implemented: now it
1009           is #defined to be one of: FLT_MAX, DBL_MAX, HUGE_VAL, HUGE_VALF, or
1010           a large numeric constant. previously it was a variable that was
1011           exported from the library. this simplifies the configuration and
1012           build process quite a bit, especially in the case of DLLs.
1013         
1014         * removed the old, deprecated collision system (geom.cpp,space.cpp,
1015           geom.h,space.h,odecpp_old_collision.h). the ODE_OLD_COLLISION
1016           configuration setting no longer has any meaning.
1017         
1018         * removed support for dGeomGroups, which have been deprecated for
1019           a while and are equivalent to 'spaces' anyway.
1021 04/13/04 russ
1023         * bug fix in dMassSetCappedCylinder(), from Matthew D. Hancher.
1025 04/08/04 russ
1027         * added trimesh-CCylinder capability, from Vadim Macagon
1028           <vadim_mcagon@hotmail.com>.
1030 04/04/04 adam
1032         * yet another rewrite of triangle-box collision code, this
1033         time based on code donated by Croteam, ported by asko@jetti.org
1034         and tweaked by Erwin.
1036 04/04/04 adam
1038         * merged trimesh-trimesh collision code by
1039         Jeffrey Smith <jeffreys@Softimage.com>.
1041         * changed it to not break the trimesh interface, fix
1042         some GCC compilation problems, bring it up to date with
1043         ODE changes from 2003-11-15 -> 2004-04-04.
1045         * add ability to drop meshes on meshes in test_moving_trimesh,
1046         not as good as it could be but it's illustrative.
1048 01/16/04 adam
1050         * implement a bunch of ultra-simple TriMesh functions that were
1051         in the headers but not in the code -- patch by
1052         Vadim Macagon <vadim_mcagon@hotmail.com>
1054         * disable temporal coherence on trimeshes by default, since
1055         it has scaleability issues that don't make it a general clear win.
1057 12/01/03 adam
1059         * implement dxHashSpace::collide2(), not particularly efficiently.
1061 11/14/03 adam
1063         * applied several Trimesh fixes and improvements from
1064         Aras Pranckevicius <nearaz@interamotion.com>
1066 10/22/03 adam
1068         * apply Nguyen Binh's work for removing many dSetZero() calls
1069         and some other extraneous initializations.
1071 07/29/03 martin
1073         * added dJointAdd*Torque/Force().
1075 07/10/03 russ
1077         * added the StepFast code, by David Whittaker.
1079 07/02/03 martin
1081         * added dMassSet*Total().
1083 07/01/03 martin
1085         * added joint limits and motors to universal joints.
1087         * reversed the polarity of the dJOINT_REVERSE flag.
1089 06/30/03 russ
1091         * added the TriMesh geom class and the quad tree space to the ODE
1092           core. both of these were developed by Erwin de Vries. added OPCODE
1093           to the ODE distribution, this is required by TriMesh.
1095 06/23/03 martin
1097         * added dGeomSetQuaternion() and dGeomGetQuaternion()
1098         
1099         * added dJointGet*Anchor2()
1101 05/07/03 russ
1103         * added dGeomGetSpace().
1105 02/05/03 russ
1107         * added dMassSetCylinder().
1109 12/07/02 russ
1111         * added dAreConnectedExcluding().
1113 11/30/02 russ
1115         * added the ray geom class.
1117         * added the dGeomXXXPointDepth() functions.
1119         * added a collision test infrastructure, and some more tests.
1121 11/24/02 russ
1123         * added support for multiple box-box contacts.
1125 11/10/02 russ
1127         * added new collision system. select between the old/new system by
1128           setting the ODE_OLD_COLLISION variable in config/user-settings.
1130 10/28/02 russ
1132         * fixed two problems in the LCP code to improve the reliability of
1133           the dContactApprox1 contact mode.
1135         * added a FAQ question about rolling bodies getting stuck when they
1136           hit multiple geoms.
1138 09/08/02 russ
1140         * added dClosestLineSegmentPoints().
1141         * implemented dCollideCB().
1143 08/28/02 russ
1145         * added dJointSetFeedback() and dJointGetFeedback().
1147 08/05/02 russ
1149         * added dGeomTransformSetInfo() and dGeomTransformGetInfo().
1151 07/13/02 russ
1153         * added dBodySetForce(), dBodySetTorque(), dWorldImpulseToForce(),
1154           dBodyGetPosRelPoint(), dBodyGetPosRelPoint(), dBodyVectorToWorld(),
1155           dBodyVectorFromWorld().
1157         * added dBodyGetPointVel() (thanks to Colin Reed).
1159         * added a new C++ interface (from Martin C. Martin, with modifications
1160           by russ). the old C++ interface is now in odecpp_old.h.
1162 06/25/02 russ
1164         * added an additional BSD-style licensing option for ODE.
1166 06/23/02 russ
1168         * added dCloseODE(), contributed by Nate Waddoups and David McClurg.
1170 05/16/02 russ
1172         * added dSpaceQuery(), contributed by Nate Waddoups.
1174 04/07/02 russ
1176         * added a section to the documentation for universal joints.
1177           this includes a picture of the joint.
1179 04/05/02 russ
1181         * added a universal joint class (generously contributed by
1182           Martin C. Martin). it doesn't (yet) have a motor or joint limits,
1183           but it does come with tests.
1185 03/11/02 russ
1187         * makefile changes to accomodate OSs with command line length
1188           limitations (thanks to Norman Lin).
1190 01/06/02 russ
1192         * added the dBodySetGravityMode() and dBodyGetGravityMode()
1193           functions, which change the dxBodyNoGravity body flag.
1195         * added support for building a DLL with MSVC - there is now a
1196           msvc-dll target. thanks to Norman Lin for doing this.
1198 12/28/01 russ
1200         * added the dParamCFM joint parameter.
1202 12/24/01 russ
1204         * reworked the build system to make it more cross-platform.
1205           there is now a single top-level makefile and a configurator.c
1206           program. see the INSTALL file for details.
1208 12/04/01 russ
1210         * the "angular motor" joint has been completed, and a new section
1211           has been added to the documentation.
1213 11/26/01 russ
1215         * added a new joint type: "angular motor". using this joint is a good
1216           way to get ball-joint motors and limits. this is work in progress -
1217           it has not been fully implemented or tested yet.
1219 11/22/01 russ
1221         * replaced the mmap()-based joint group stack (stack.cpp) with a
1222           malloc()-based arena stack (obstack.cpp). this will be more
1223           portable and should not impact performance.
1225 11/12/01 russ
1227         * changed the meaning of the 'flags' parameter to dCollide() and
1228           related functions: now the size of the contact buffer is kept in
1229           the lower 16 bits. this change will be backward compatible.
1231         * added dBodyGetFiniteRotationMode() and dBodyGetFiniteRotationAxis().
1233         * added dBodyAddForceAtRelPos() function.
1235 11/11/01 russ
1237         * added the ability to manually enable and disable bodies.
1238           see dBodyEnable(), dBodyDisable(), dBodyIsEnabled().
1240         * fixed a potential bug: when a world is destroyed that contains
1241           joints in joint groups, those joints are marked as "deactivated" in
1242           the joint group, so when the joint group is destroyed they can be
1243           ignored.
1245         * the test_boxstack demo has new options to enable and disable bodies.
1247         * new configuration parameter in config.h: dEFFICIENT_SIZE.
1249 11/11/01 russ
1251         * started the change log for ODE. changes older than today were added
1252           to this file by inspecting the CVS logs.
1254 11/05/01 russ
1256         * added REAL() constructions for floating point numbers, to prevent
1257           many warnings when compiling under VC++.
1259 11/03/01 russ
1261         * added geometry transform class, documented composite objects.
1263         * added collision rule: no contacts if both geoms on the same body.
1264           this is not the best rule, may have to remove this in the future.
1266         * new dMassAdd() function.
1268         * capped cylinder to capped cylinder collision function.
1270 10/31/01 russ
1272         * increase CFM in some demos to make them more robust.
1274 10/29/01 russ
1276         * added new accessor functions.
1278 10/19/01 russ
1280         * added the dJOINT_TWOBODIES flag to the joint, that says it can not
1281           be attached to just one body.
1283 10/12/01 russ
1285         * fixed a collision bug in dCollide() that was causing memory
1286           corruption when multiple contacts were being returned.
1288 10/11/01 russ
1290         * joints can now return m=0 to be "inactive". added a "null" joint
1291           to test this.
1293 10/09/01 russ
1295         * in the LCP solver, try to fail gracefully when s <= 0.
1297         * dAABBTestFn() API change.
1299 10/08/01 russ
1301         * fixed a contact swapping bug in dCollide().
1303 10/07/01 russ
1305         * added capped cylinder geometry object.
1307 09/30/01 russ
1309         * the test_buggy demo now uses geometry groups.
1311         * added a dAABBTestFn field in the geometry classes.
1313 09/29/01 russ
1315         * added geometry groups.
1317 09/20/01 russ
1319         * added finite rotation stuff.