Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merge: 7 -> main #559

Merged
merged 16 commits into from
Oct 11, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
12 changes: 6 additions & 6 deletions .github/ci/packages.apt
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
libbenchmark-dev
libdart-collision-bullet-dev
libdart-collision-ode-dev
libdart-dev
libdart-external-ikfast-dev
libdart-external-odelcpsolver-dev
libdart-utils-urdf-dev
libdart6.13-collision-bullet-dev
libdart6.13-collision-ode-dev
libdart6.13-dev
libdart6.13-external-ikfast-dev
libdart6.13-external-odelcpsolver-dev
libdart6.13-utils-urdf-dev
libeigen3-dev
libgz-cmake3-dev
libgz-common5-dev
Expand Down
2 changes: 1 addition & 1 deletion CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ find_package(gz-cmake3 REQUIRED)
set(CMAKE_CXX_STANDARD 17)
set(CMAKE_CXX_STANDARD_REQUIRED ON)

gz_configure_project(VERSION_SUFFIX pre1)
gz_configure_project(VERSION_SUFFIX)

#============================================================================
# Set project-specific options
Expand Down
57 changes: 56 additions & 1 deletion Changelog.md
Original file line number Diff line number Diff line change
@@ -1,9 +1,52 @@
## Gazebo Physics 7.x

### Gazebo Physics 7.x.x (202X-XX-XX)
### Gazebo Physics 7.0.0 (2023-09-29)

1. dartsim: Fix sign convention error with contact surface motion velocities
* [Pull request #556](https://github.com/gazebosim/gz-physics/pull/556)

1. Make dartsim/World.hh header private
* [Pull request #551](https://github.com/gazebosim/gz-physics/pull/551)

1. Documentation fixes
* [Pull request #542](https://github.com/gazebosim/gz-physics/pull/542)

1. Mimic constraint feature using bullet-featherstone
* [Pull request #517](https://github.com/gazebosim/gz-physics/pull/517)

1. ign -> gz
* [Pull request #524](https://github.com/gazebosim/gz-physics/pull/524)

1. Reduce error to debug messsage for mesh construction
* [Pull request #531](https://github.com/gazebosim/gz-physics/pull/531)

1. Infrastructure
* [Pull request #528](https://github.com/gazebosim/gz-physics/pull/528)
* [Pull request #553](https://github.com/gazebosim/gz-physics/pull/553)

1. Bumps in harmonic : sdformat14
* [Pull request #526](https://github.com/gazebosim/gz-physics/pull/526)

1. EllipsoidShape: use const references in API
* [Pull request #521](https://github.com/gazebosim/gz-physics/pull/521)

1. Fixed Dartsim SDFFeatures_TEST
* [Pull request #405](https://github.com/gazebosim/gz-physics/pull/405)

1. ⬆️ Bump main to 7.0.0~pre1
* [Pull request #399](https://github.com/gazebosim/gz-physics/pull/399)


## Gazebo Physics 6.x

### Gazebo Physics 6.5.1 (2023-09-26)

1. joint_features test: reduce console spam
* [Pull request #543](https://github.com/gazebosim/gz-physics/pull/543)

1. Cleaning up bullet memory use issues
* [Pull request #539](https://github.com/gazebosim/gz-physics/pull/539)

### Gazebo Physics 6.5.0 (2023-08-30)

1. Add optional binary relocatability
Expand Down Expand Up @@ -228,6 +271,18 @@

## Gazebo Physics 5.x

### Gazebo Physics 5.3.2 (2023-09-01)

1. Fix a crash due to an invalid pointer
* [Pull request #486](https://github.com/gazebosim/gz-physics/pull/486)

1. Infrastructure
* [Pull request #490](https://github.com/gazebosim/gz-physics/pull/490)
* [Pull request #488](https://github.com/gazebosim/gz-physics/pull/488)

1. Rename COPYING to LICENSE
* [Pull request #487](https://github.com/gazebosim/gz-physics/pull/487)

### Gazebo Physics 5.3.1 (2023-02-16)

1. Fix memory corruption due to faulty refcount tracking
Expand Down
30 changes: 27 additions & 3 deletions bullet-featherstone/src/Base.hh
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@
#include <BulletDynamics/Featherstone/btMultiBodyGearConstraint.h>
#include <BulletDynamics/Featherstone/btMultiBodyJointFeedback.h>
#include <BulletDynamics/Featherstone/btMultiBodyJointMotor.h>
#include <BulletDynamics/Featherstone/btMultiBodyJointLimitConstraint.h>
#include <BulletDynamics/Featherstone/btMultiBodyLinkCollider.h>
#include <BulletDynamics/Featherstone/btMultiBodyFixedConstraint.h>
#include <LinearMath/btVector3.h>
Expand Down Expand Up @@ -166,9 +167,10 @@ struct JointInfo
Identity model;
// This field gets set by AddJoint
std::size_t indexInGzModel = 0;
btMultiBodyJointMotor* motor = nullptr;
btScalar effort = 0;

std::shared_ptr<btMultiBodyJointMotor> motor = nullptr;
std::shared_ptr<btMultiBodyJointLimitConstraint> jointLimits = nullptr;
std::shared_ptr<btMultiBodyFixedConstraint> fixedConstraint = nullptr;
std::shared_ptr<btMultiBodyGearConstraint> gearConstraint = nullptr;
std::shared_ptr<btMultiBodyJointFeedback> jointFeedback = nullptr;
Expand Down Expand Up @@ -357,6 +359,30 @@ class Base : public Implements3d<FeatureList<Feature>>
return this->GenerateIdentity(id, joint);
}

public: ~Base() override {
// The order of destruction between meshesGImpact and triangleMeshes is
// important.
this->meshesGImpact.clear();
this->triangleMeshes.clear();

this->joints.clear();

for (const auto &[k, link] : links)
{
auto *model = this->ReferenceInterface<ModelInfo>(link->model);
auto *world = this->ReferenceInterface<WorldInfo>(model->world);
if (link->collider != nullptr)
{
world->world->removeCollisionObject(link->collider.get());
}
}

this->collisions.clear();
this->links.clear();
this->models.clear();
this->worlds.clear();
}

public: using WorldInfoPtr = std::shared_ptr<WorldInfo>;
public: using ModelInfoPtr = std::shared_ptr<ModelInfo>;
public: using LinkInfoPtr = std::shared_ptr<LinkInfo>;
Expand All @@ -369,8 +395,6 @@ class Base : public Implements3d<FeatureList<Feature>>
public: std::unordered_map<std::size_t, CollisionInfoPtr> collisions;
public: std::unordered_map<std::size_t, JointInfoPtr> joints;

// Note, the order of triangleMeshes and meshesGImpact is important. Reversing
// the order causes segfaults on macOS during destruction.
public: std::vector<std::unique_ptr<btTriangleMesh>> triangleMeshes;
public: std::vector<std::unique_ptr<btGImpactMeshShape>> meshesGImpact;
};
Expand Down
14 changes: 8 additions & 6 deletions bullet-featherstone/src/FreeGroupFeatures.cc
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,8 @@

#include "FreeGroupFeatures.hh"

#include <memory>

namespace gz {
namespace physics {
namespace bullet_featherstone {
Expand Down Expand Up @@ -64,23 +66,23 @@
// Free groups in bullet-featherstone are always represented by ModelInfo
const auto *model = this->ReferenceInterface<ModelInfo>(_groupID);

if(model)
if (model != nullptr)

Check warning on line 69 in bullet-featherstone/src/FreeGroupFeatures.cc

View check run for this annotation

Codecov / codecov/patch

bullet-featherstone/src/FreeGroupFeatures.cc#L69

Added line #L69 was not covered by tests
{
// Set angular velocity the each one of the joints of the model
for (const auto& jointID : model->jointEntityIds)
{
auto jointInfo = this->joints[jointID];
if (!jointInfo->motor)
{
auto modelInfo = this->ReferenceInterface<ModelInfo>(jointInfo->model);
jointInfo->motor = new btMultiBodyJointMotor(
auto *modelInfo = this->ReferenceInterface<ModelInfo>(jointInfo->model);
jointInfo->motor = std::make_shared<btMultiBodyJointMotor>(

Check warning on line 78 in bullet-featherstone/src/FreeGroupFeatures.cc

View check run for this annotation

Codecov / codecov/patch

bullet-featherstone/src/FreeGroupFeatures.cc#L77-L78

Added lines #L77 - L78 were not covered by tests
modelInfo->body.get(),
std::get<InternalJoint>(jointInfo->identifier).indexInBtModel,
0,
0,
jointInfo->effort);
static_cast<btScalar>(0),
static_cast<btScalar>(jointInfo->effort));

Check warning on line 83 in bullet-featherstone/src/FreeGroupFeatures.cc

View check run for this annotation

Codecov / codecov/patch

bullet-featherstone/src/FreeGroupFeatures.cc#L82-L83

Added lines #L82 - L83 were not covered by tests
auto *world = this->ReferenceInterface<WorldInfo>(modelInfo->world);
world->world->addMultiBodyConstraint(jointInfo->motor);
world->world->addMultiBodyConstraint(jointInfo->motor.get());

Check warning on line 85 in bullet-featherstone/src/FreeGroupFeatures.cc

View check run for this annotation

Codecov / codecov/patch

bullet-featherstone/src/FreeGroupFeatures.cc#L85

Added line #L85 was not covered by tests
}

if (jointInfo->motor)
Expand Down
8 changes: 4 additions & 4 deletions bullet-featherstone/src/JointFeatures.cc
Original file line number Diff line number Diff line change
Expand Up @@ -285,14 +285,14 @@
if (!jointInfo->motor)
{
auto modelInfo = this->ReferenceInterface<ModelInfo>(jointInfo->model);
jointInfo->motor = new btMultiBodyJointMotor(
jointInfo->motor = std::make_shared<btMultiBodyJointMotor>(
modelInfo->body.get(),
std::get<InternalJoint>(jointInfo->identifier).indexInBtModel,
0,
0,
jointInfo->effort);
static_cast<btScalar>(0),

Check warning on line 292 in bullet-featherstone/src/JointFeatures.cc

View check run for this annotation

Codecov / codecov/patch

bullet-featherstone/src/JointFeatures.cc#L292

Added line #L292 was not covered by tests
static_cast<btScalar>(jointInfo->effort));
auto *world = this->ReferenceInterface<WorldInfo>(modelInfo->world);
world->world->addMultiBodyConstraint(jointInfo->motor);
world->world->addMultiBodyConstraint(jointInfo->motor.get());
}

jointInfo->motor->setVelocityTarget(static_cast<btScalar>(_value));
Expand Down
21 changes: 11 additions & 10 deletions bullet-featherstone/src/SDFFeatures.cc
Original file line number Diff line number Diff line change
Expand Up @@ -581,10 +581,12 @@ Identity SDFFeatures::ConstructSdfModel(
model->body->getLink(i).m_jointMaxForce =
static_cast<btScalar>(joint->Axis()->Effort());
jointInfo->effort = static_cast<btScalar>(joint->Axis()->Effort());
btMultiBodyConstraint *con = new btMultiBodyJointLimitConstraint(

jointInfo->jointLimits =
std::make_shared<btMultiBodyJointLimitConstraint>(
model->body.get(), i, static_cast<btScalar>(joint->Axis()->Lower()),
static_cast<btScalar>(joint->Axis()->Upper()));
world->world->addMultiBodyConstraint(con);
world->world->addMultiBodyConstraint(jointInfo->jointLimits.get());
}

jointInfo->jointFeedback = std::make_shared<btMultiBodyJointFeedback>();
Expand Down Expand Up @@ -884,21 +886,20 @@ bool SDFFeatures::AddSdfCollision(

// NOTE: Bullet does not appear to support different surface properties
// for different shapes attached to the same link.
auto collider = std::make_unique<btMultiBodyLinkCollider>(
linkInfo->collider = std::make_unique<btMultiBodyLinkCollider>(
model->body.get(), linkIndexInModel);

linkInfo->shape->addChildShape(btInertialToCollision, shape.get());

collider->setCollisionShape(linkInfo->shape.get());
collider->setRestitution(static_cast<btScalar>(restitution));
collider->setRollingFriction(static_cast<btScalar>(rollingFriction));
collider->setFriction(static_cast<btScalar>(mu));
collider->setAnisotropicFriction(
linkInfo->collider->setCollisionShape(linkInfo->shape.get());
linkInfo->collider->setRestitution(static_cast<btScalar>(restitution));
linkInfo->collider->setRollingFriction(
static_cast<btScalar>(rollingFriction));
linkInfo->collider->setFriction(static_cast<btScalar>(mu));
linkInfo->collider->setAnisotropicFriction(
btVector3(static_cast<btScalar>(mu), static_cast<btScalar>(mu2), 1),
btCollisionObject::CF_ANISOTROPIC_FRICTION);

linkInfo->collider = std::move(collider);

if (linkIndexInModel >= 0)
{
model->body->getLink(linkIndexInModel).m_collider =
Expand Down
20 changes: 20 additions & 0 deletions bullet/src/Base.hh
Original file line number Diff line number Diff line change
Expand Up @@ -238,6 +238,26 @@ class Base : public Implements3d<FeatureList<Feature>>
return this->GenerateIdentity(id, this->joints.at(id));
}

public: ~Base() override
{
this->joints.clear();

for (const auto &[k, link] : links)
{
auto *model = this->ReferenceInterface<ModelInfo>(link->model);
auto *world = this->ReferenceInterface<WorldInfo>(model->world);
if (link->link != nullptr)
{
world->world->removeCollisionObject(link->link.get());
}
}

this->collisions.clear();
this->links.clear();
this->models.clear();
this->worlds.clear();
}

public: using WorldInfoPtr = std::shared_ptr<WorldInfo>;
public: using ModelInfoPtr = std::shared_ptr<ModelInfo>;
public: using LinkInfoPtr = std::shared_ptr<LinkInfo>;
Expand Down
4 changes: 0 additions & 4 deletions dartsim/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -11,10 +11,6 @@ if (MSVC)
target_compile_options(${features} INTERFACE "/permissive-")
endif()

install(
DIRECTORY include/
DESTINATION "${GZ_INCLUDE_INSTALL_DIR_FULL}")

gz_get_libsources_and_unittests(sources test_sources)

# TODO(MXG): Think about a gz_add_plugin(~) macro for gz-cmake
Expand Down
3 changes: 2 additions & 1 deletion dartsim/src/AddedMassFeatures_TEST.cc
Original file line number Diff line number Diff line change
Expand Up @@ -32,14 +32,15 @@
#include <gz/physics/sdf/ConstructLink.hh>
#include <gz/physics/sdf/ConstructModel.hh>
#include <gz/physics/sdf/ConstructWorld.hh>
#include <gz/physics/dartsim/World.hh>

#include <sdf/Link.hh>
#include <sdf/Root.hh>
#include <sdf/World.hh>

#include <test/Utils.hh>

#include "World.hh"

struct TestFeatureList : gz::physics::FeatureList<
gz::physics::GetEntities,
gz::physics::GetBasicJointState,
Expand Down
3 changes: 1 addition & 2 deletions dartsim/src/CustomFeatures.hh
Original file line number Diff line number Diff line change
Expand Up @@ -20,9 +20,8 @@

#include <gz/physics/Implements.hh>

#include <gz/physics/dartsim/World.hh>

#include "Base.hh"
#include "World.hh"

namespace gz {
namespace physics {
Expand Down
4 changes: 2 additions & 2 deletions dartsim/src/SDFFeatures_TEST.cc
Original file line number Diff line number Diff line change
Expand Up @@ -43,8 +43,6 @@
#include <gz/physics/sdf/ConstructNestedModel.hh>
#include <gz/physics/sdf/ConstructWorld.hh>

#include <gz/physics/dartsim/World.hh>

#include <sdf/Collision.hh>
#include <sdf/Joint.hh>
#include <sdf/JointAxis.hh>
Expand All @@ -54,6 +52,8 @@

#include <test/Utils.hh>

#include "World.hh"

using namespace gz;

struct TestFeatureList : physics::FeatureList<
Expand Down
Loading
Loading