Physical properties of the simulated model requires checking
Closed this issue · 6 comments
As the model behaves strangely in simulation I guess there's something wrong with its description and/or physical properties defined in URDF (collision
, inertia
, and joints
tags in general should be checked).
Potentially helpful resources: http://gazebosim.org/tutorials/?tut=ros_urdf
It should make more sense to resolve #1 first.
Found issues:
-
(Solved) In gazebo, model is dropped from some height instead of being spawned right on the ground
-
(Ignorable) Left wheels are somewhat more outside of the body than right ones. Not sure whether this may affect physics, but if that's an easy to track and fix issue (and I suppose it is), then it'd probably be worth looking into.
-
(Solved) After adding the camera model car inertia is tilted to the right (I'm not sure if it causes any problems though).
-
Contact with the ground is not constant (it flickers for at least two wheels), not sure what causes this behaviour and how problematic it is.
-
(Solved) Lidar laser and mesh used for visualization are not aligned.
-
Wheels are slowly rotating. What is interesting - front wheel revolute forwards, while rear wheels - backwards.
The rotation is very slow, actually optically hardly noticeable. I only noticed it accidentally while messing around in gazebo - attributeangle_0
was constantly changing a little bit over time.
Note: this strange behaviour ofangle_0
attribute can be observed for (almost?) all joints actually. -
(Solved) Body inertia is skewed; in urdf everything seems to be ok, but somehow in gazebo it is visualized like that:
I can add:
3. After adding the camera model car inertia is tilted to the right (I'm not sure if it causes any problems though).
4. Contact with the ground is not constant (it flickers for at least two wheels), not sure what causes this behaviour and how problematic it is.
5. Lidar laser and mesh used for visualization are not aligned.
Update:
ad 1. spawning the car too high was caused by the too high value of argument x
in car_gazebo.launch
file; was 1.0
, changed to 0.0325
(i.e. wheel_radius
) in 6dc02c8.
Update:
ad 3. and 7.: the tilt was caused by parameter d435i_cam_depth_py
; it is responsible for offset of the camera (in terms of joint to base_link placement, visualization and collision) along the Y axis. The initial value was 0.0175, which caused the mass not to be symmetrically distributed. Changing the value to 0 fixed it. (commit 26a4e4b)
Update:
ad 2. After further inspection, it is more of a visualization issue and should not affect physical properties of the model; the collisions and inertias seem to be symmetrical.
ad 5. Fixed in f3343d9.