Skip to content

Commit

Permalink
Merge branch 'gz-sim7' into scpeters/merge_7_8
Browse files Browse the repository at this point in the history
  • Loading branch information
scpeters committed Nov 13, 2023
2 parents e97053f + 409efa7 commit b86fc08
Show file tree
Hide file tree
Showing 11 changed files with 42 additions and 54 deletions.
14 changes: 13 additions & 1 deletion src/systems/advanced_lift_drag/AdvancedLiftDrag.cc
Original file line number Diff line number Diff line change
Expand Up @@ -59,6 +59,7 @@
#include "gz/sim/components/Name.hh"
#include "gz/sim/components/ExternalWorldWrenchCmd.hh"
#include "gz/sim/components/Pose.hh"
#include "gz/sim/components/Wind.hh"

using namespace gz;
using namespace sim;
Expand Down Expand Up @@ -481,6 +482,13 @@ void AdvancedLiftDragPrivate::Update(EntityComponentManager &_ecm)
const auto worldPose =
_ecm.Component<components::WorldPose>(this->linkEntity);

// get wind as a component from the _ecm
components::WorldLinearVelocity *windLinearVel = nullptr;
if(_ecm.EntityByComponents(components::Wind()) != kNullEntity){
Entity windEntity = _ecm.EntityByComponents(components::Wind());
windLinearVel =
_ecm.Component<components::WorldLinearVelocity>(windEntity);
}

std::vector<components::JointPosition*> controlJointPosition_vec(
this->num_ctrl_surfaces);
Expand All @@ -499,8 +507,12 @@ void AdvancedLiftDragPrivate::Update(EntityComponentManager &_ecm)

const auto &pose = worldPose->Data();
const auto cpWorld = pose.Rot().RotateVector(this->cp);
const auto air_velocity = worldLinVel->Data() + worldAngVel->Data().Cross(
auto air_velocity = worldLinVel->Data() + worldAngVel->Data().Cross(
cpWorld);
if (windLinearVel != nullptr){
air_velocity = worldLinVel->Data() + worldAngVel->Data().Cross(
cpWorld) - windLinearVel->Data();
}

// Define body frame: X forward, Z downward, Y out the right wing
gz::math::Vector3d body_x_axis = pose.Rot().RotateVector(this->forward);
Expand Down
2 changes: 2 additions & 0 deletions src/systems/advanced_lift_drag/AdvancedLiftDrag.hh
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,8 @@ namespace systems
/// https://github.com/PX4/PX4-Autopilot/blob/main/Tools/simulation/
/// gz/tools/avl_automation/
///
/// Note: Wind calculations can be enabled by setting the wind parameter
/// in the world file.
///
/// ## System Parameters
///
Expand Down
8 changes: 2 additions & 6 deletions src/systems/diff_drive/DiffDrive.cc
Original file line number Diff line number Diff line change
Expand Up @@ -187,18 +187,14 @@ void DiffDrive::Configure(const Entity &_entity,
return;
}

// Ugly, but needed because the sdf::Element::GetElement is not a const
// function and _sdf is a const shared pointer to a const sdf::Element.
auto ptr = const_cast<sdf::Element *>(_sdf.get());

// Get params from SDF
sdf::ElementPtr sdfElem = ptr->GetElement("left_joint");
auto sdfElem = _sdf->FindElement("left_joint");
while (sdfElem)
{
this->dataPtr->leftJointNames.push_back(sdfElem->Get<std::string>());
sdfElem = sdfElem->GetNextElement("left_joint");
}
sdfElem = ptr->GetElement("right_joint");
sdfElem = _sdf->FindElement("right_joint");
while (sdfElem)
{
this->dataPtr->rightJointNames.push_back(sdfElem->Get<std::string>());
Expand Down
3 changes: 1 addition & 2 deletions src/systems/joint_state_publisher/JointStatePublisher.cc
Original file line number Diff line number Diff line change
Expand Up @@ -64,8 +64,7 @@ void JointStatePublisher::Configure(
// specified joints. Otherwise, publish all the joints.
if (_sdf->HasElement("joint_name"))
{
sdf::Element *ptr = const_cast<sdf::Element *>(_sdf.get());
sdf::ElementPtr elem = ptr->GetElement("joint_name");
auto elem = _sdf->FindElement("joint_name");
while (elem)
{
std::string jointName = elem->Get<std::string>();
Expand Down
3 changes: 1 addition & 2 deletions src/systems/joint_traj_control/JointTrajectoryController.cc
Original file line number Diff line number Diff line change
Expand Up @@ -811,8 +811,7 @@ std::vector<T> JointParameters::Parse(

if (_sdf->HasElement(_parameterName))
{
sdf::ElementPtr param = const_cast<sdf::Element *>(
_sdf.get())->GetElement(_parameterName);
auto param = _sdf->FindElement(_parameterName);
while (param)
{
output.push_back(param->Get<T>());
Expand Down
3 changes: 1 addition & 2 deletions src/systems/log/LogRecord.cc
Original file line number Diff line number Diff line change
Expand Up @@ -338,8 +338,7 @@ bool LogRecordPrivate::Start(const std::string &_logPath,
// Get the topics to record, if any.
if (this->sdf->HasElement("record_topic"))
{
auto ptr = const_cast<sdf::Element *>(this->sdf.get());
sdf::ElementPtr recordTopicElem = ptr->GetElement("record_topic");
auto recordTopicElem = this->sdf->FindElement("record_topic");

// This is used to determine if a topic is a regular expression.
std::regex regexMatch(".*[\\*\\?\\[\\]\\(\\)\\.]+.*");
Expand Down
14 changes: 5 additions & 9 deletions src/systems/log_video_recorder/LogVideoRecorder.cc
Original file line number Diff line number Diff line change
Expand Up @@ -171,13 +171,9 @@ void LogVideoRecorder::Configure(
this->dataPtr->node.Advertise<msgs::StringMsg>(
"/log_video_recorder/status");

// Ugly, but needed because the sdf::Element::GetElement is not a const
// function and _sdf is a const shared pointer to a const sdf::Element.
auto ptr = const_cast<sdf::Element *>(_sdf.get());

if (_sdf->HasElement("entity"))
{
auto entityElem = ptr->GetElement("entity");
auto entityElem = _sdf->FindElement("entity");
while (entityElem)
{
this->dataPtr->modelsToRecord.insert(entityElem->Get<std::string>());
Expand All @@ -187,7 +183,7 @@ void LogVideoRecorder::Configure(

if (_sdf->HasElement("region"))
{
sdf::ElementPtr regionElem = ptr->GetElement("region");
auto regionElem = _sdf->FindElement("region");
while (regionElem)
{
auto min = regionElem->Get<math::Vector3d>("min");
Expand All @@ -201,14 +197,14 @@ void LogVideoRecorder::Configure(

if (_sdf->HasElement("start_time"))
{
auto t = ptr->Get<double>("start_time");
auto t = _sdf->Get<double>("start_time");
this->dataPtr->startTime =
std::chrono::milliseconds(static_cast<int64_t>(t * 1000.0));
}

if (_sdf->HasElement("end_time"))
{
auto t = ptr->Get<double>("end_time");
auto t = _sdf->Get<double>("end_time");
std::chrono::milliseconds ms(static_cast<int64_t>(t * 1000.0));
if (this->dataPtr->startTime > ms)
{
Expand All @@ -222,7 +218,7 @@ void LogVideoRecorder::Configure(

if (_sdf->HasElement("exit_on_finish"))
{
this->dataPtr->exitOnFinish = ptr->Get<bool>("exit_on_finish");
this->dataPtr->exitOnFinish = _sdf->Get<bool>("exit_on_finish");
}

this->dataPtr->loadTime = std::chrono::system_clock::now();
Expand Down
12 changes: 4 additions & 8 deletions src/systems/mecanum_drive/MecanumDrive.cc
Original file line number Diff line number Diff line change
Expand Up @@ -194,31 +194,27 @@ void MecanumDrive::Configure(const Entity &_entity,
return;
}

// Ugly, but needed because the sdf::Element::GetElement is not a const
// function and _sdf is a const shared pointer to a const sdf::Element.
auto ptr = const_cast<sdf::Element *>(_sdf.get());

// Get params from SDF
sdf::ElementPtr sdfElem = ptr->GetElement("front_left_joint");
auto sdfElem = _sdf->FindElement("front_left_joint");
while (sdfElem)
{
this->dataPtr->frontLeftJointNames.push_back(sdfElem->Get<std::string>());
sdfElem = sdfElem->GetNextElement("front_left_joint");
}
sdfElem = ptr->GetElement("front_right_joint");
sdfElem = _sdf->FindElement("front_right_joint");
while (sdfElem)
{
this->dataPtr->frontRightJointNames.push_back(sdfElem->Get<std::string>());
sdfElem = sdfElem->GetNextElement("front_right_joint");
}

sdfElem = ptr->GetElement("back_left_joint");
sdfElem = _sdf->FindElement("back_left_joint");
while (sdfElem)
{
this->dataPtr->backLeftJointNames.push_back(sdfElem->Get<std::string>());
sdfElem = sdfElem->GetNextElement("back_left_joint");
}
sdfElem = ptr->GetElement("back_right_joint");
sdfElem = _sdf->FindElement("back_right_joint");
while (sdfElem)
{
this->dataPtr->backRightJointNames.push_back(sdfElem->Get<std::string>());
Expand Down
17 changes: 7 additions & 10 deletions src/systems/shader_param/ShaderParam.cc
Original file line number Diff line number Diff line change
Expand Up @@ -144,14 +144,11 @@ void ShaderParam::Configure(const Entity &_entity,
EventManager &_eventMgr)
{
GZ_PROFILE("ShaderParam::Configure");
// Ugly, but needed because the sdf::Element::GetElement is not a const
// function and _sdf is a const shared pointer to a const sdf::Element.
auto sdf = const_cast<sdf::Element *>(_sdf.get());

if (sdf->HasElement("param"))
if (_sdf->HasElement("param"))
{
// loop and parse all shader params
sdf::ElementPtr paramElem = sdf->GetElement("param");
auto paramElem = _sdf->FindElement("param");
while (paramElem)
{
if (!paramElem->HasElement("shader") ||
Expand All @@ -176,7 +173,7 @@ void ShaderParam::Configure(const Entity &_entity,

if (paramElem->HasElement("arg"))
{
sdf::ElementPtr argElem = paramElem->GetElement("arg");
auto argElem = paramElem->FindElement("arg");
while (argElem)
{
spv.args.push_back(argElem->Get<std::string>());
Expand All @@ -197,14 +194,14 @@ void ShaderParam::Configure(const Entity &_entity,
}

// parse path to shaders
if (!sdf->HasElement("shader"))
if (!_sdf->HasElement("shader"))
{
gzerr << "Unable to load shader param system. "
<< "Missing <shader> SDF element." << std::endl;
return;
}
// allow mulitple shader SDF element for different shader languages
sdf::ElementPtr shaderElem = sdf->GetElement("shader");
auto shaderElem = _sdf->FindElement("shader");
while (shaderElem)
{
if (!shaderElem->HasElement("vertex") ||
Expand All @@ -223,11 +220,11 @@ void ShaderParam::Configure(const Entity &_entity,
ShaderParamPrivate::ShaderUri shader;
shader.language = api;

sdf::ElementPtr vertexElem = shaderElem->GetElement("vertex");
auto vertexElem = shaderElem->FindElement("vertex");
shader.vertexShaderUri = common::findFile(
asFullPath(vertexElem->Get<std::string>(),
this->dataPtr->modelPath));
sdf::ElementPtr fragmentElem = shaderElem->GetElement("fragment");
auto fragmentElem = shaderElem->FindElement("fragment");
shader.fragmentShaderUri = common::findFile(
asFullPath(fragmentElem->Get<std::string>(),
this->dataPtr->modelPath));
Expand Down
12 changes: 4 additions & 8 deletions src/systems/tracked_vehicle/TrackedVehicle.cc
Original file line number Diff line number Diff line change
Expand Up @@ -233,25 +233,21 @@ void TrackedVehicle::Configure(const Entity &_entity,
if (!links.empty())
this->dataPtr->canonicalLink = Link(links[0]);

// Ugly, but needed because the sdf::Element::GetElement is not a const
// function and _sdf is a const shared pointer to a const sdf::Element.
auto ptr = const_cast<sdf::Element *>(_sdf.get());

std::unordered_map<std::string, sdf::ElementPtr> tracks;
std::unordered_map<std::string, sdf::ElementConstPtr> tracks;

if (_sdf->HasElement("body_link"))
this->dataPtr->bodyLinkName = _sdf->Get<std::string>("body_link");

// Get params from SDF
sdf::ElementPtr sdfElem = ptr->GetElement("left_track");
auto sdfElem = _sdf->FindElement("left_track");
while (sdfElem)
{
const auto& linkName = sdfElem->Get<std::string>("link");
this->dataPtr->leftTrackNames.push_back(linkName);
tracks[linkName] = sdfElem;
sdfElem = sdfElem->GetNextElement("left_track");
}
sdfElem = ptr->GetElement("right_track");
sdfElem = _sdf->FindElement("right_track");
while (sdfElem)
{
const auto& linkName = sdfElem->Get<std::string>("link");
Expand Down Expand Up @@ -294,7 +290,7 @@ void TrackedVehicle::Configure(const Entity &_entity,
if (!_sdf->HasElement(tag))
continue;

auto sdf = ptr->GetElement(tag);
auto sdf = _sdf->FindElement(tag);

// Parse speed limiter parameters.
bool hasVelocityLimits = false;
Expand Down
8 changes: 2 additions & 6 deletions src/systems/velocity_control/VelocityControl.cc
Original file line number Diff line number Diff line change
Expand Up @@ -154,14 +154,10 @@ void VelocityControl::Configure(const Entity &_entity,
<< modelTopic << "]"
<< std::endl;

// Ugly, but needed because the sdf::Element::GetElement is not a const
// function and _sdf is a const shared pointer to a const sdf::Element.
auto ptr = const_cast<sdf::Element *>(_sdf.get());

if (!ptr->HasElement("link_name"))
if (!_sdf->HasElement("link_name"))
return;

sdf::ElementPtr sdfElem = ptr->GetElement("link_name");
auto sdfElem = _sdf->FindElement("link_name");
while (sdfElem)
{
this->dataPtr->linkNames.push_back(sdfElem->Get<std::string>());
Expand Down

0 comments on commit b86fc08

Please sign in to comment.