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

ControlBoardDriver: add iJointCoupling interface #221

Merged
merged 11 commits into from
Dec 16, 2024
1 change: 1 addition & 0 deletions plugins/controlboard/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ set(HEADER_FILES

set(SRC_FILES
src/ControlBoard.cpp
src/ControlBoardData.cpp
src/ControlBoardDriver.cpp
src/ControlBoardTrajectory.cpp
)
Expand Down
19 changes: 12 additions & 7 deletions plugins/controlboard/include/ControlBoard.hh
Original file line number Diff line number Diff line change
Expand Up @@ -60,10 +60,15 @@ private:
std::string m_deviceId;
gz::sim::Entity m_modelEntity;
yarp::dev::PolyDriver m_controlBoardDriver;
yarp::dev::PolyDriver m_coupling_driver;
ControlBoardData m_controlBoardData;
yarp::os::Network m_yarpNetwork;
yarp::os::Property m_pluginParameters;
gz::sim::EntityComponentManager* m_ecm;
yarp::sig::Vector m_physicalJointsPositionBuffer, m_physicalJointsVelocityBuffer,
m_physicalJointsTorqueBuffer;
yarp::sig::Vector m_actuatedAxesPositionBuffer, m_actuatedAxesVelocityBuffer,
m_actuatedAxesTorqueBuffer;

enum class AngleUnitEnum
{
Expand All @@ -75,8 +80,7 @@ private:
void updateSimTime(const gz::sim::UpdateInfo& _info);
bool readJointsMeasurements(const gz::sim::EntityComponentManager& _ecm);
void checkForJointsHwFault();
bool
updateTrajectories(const gz::sim::UpdateInfo& _info, gz::sim::EntityComponentManager& _ecm);
bool updateTrajectories(const gz::sim::UpdateInfo& _info, gz::sim::EntityComponentManager& _ecm);
bool updateReferences(const gz::sim::UpdateInfo& _info, gz::sim::EntityComponentManager& _ecm);
double getJointTorqueFromTransmittedWrench(const gz::sim::Joint& gzJoint,
const gz::msgs::Wrench& wrench,
Expand All @@ -90,17 +94,18 @@ private:
bool setYarpPIDsParam(const std::vector<double>& pidParams,
const std::string& paramName,
std::vector<yarp::dev::Pid>& yarpPIDs,
size_t numberOfJoints);
size_t numberOfPhysicalJoints);
void setJointPositionPIDs(AngleUnitEnum cUnits, const std::vector<yarp::dev::Pid>& yarpPIDs);
double convertUserGainToGazeboGain(JointProperties& joint, double value);
double convertGazeboGainToUserGain(JointProperties& joint, double value);
double convertGazeboToUser(JointProperties& joint, double value);
double convertUserToGazebo(JointProperties& joint, double value);
double convertUserGainToGazeboGain(PhysicalJointProperties& joint, double value);
double convertGazeboGainToUserGain(PhysicalJointProperties& joint, double value);
double convertGazeboToUser(PhysicalJointProperties& joint, double value);
double convertUserToGazebo(PhysicalJointProperties& joint, double value);
bool initializeJointPositionLimits(const gz::sim::EntityComponentManager& ecm);
bool initializeTrajectoryGenerators();
bool initializeTrajectoryGeneratorReferences(yarp::os::Bottle& trajectoryGeneratorsGroup);
bool parseInitialConfiguration(std::vector<double>& initialConfigurations);
void resetPositionsAndTrajectoryGenerators(gz::sim::EntityComponentManager& ecm);
bool configureBuffers();
};

} // namespace gzyarp
25 changes: 21 additions & 4 deletions plugins/controlboard/include/ControlBoardData.hh
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
#include <yarp/conf/numeric.h>
#include <yarp/dev/IControlMode.h>
#include <yarp/dev/IInteractionMode.h>
#include <yarp/dev/IJointCoupling.h>
#include <yarp/dev/PidEnums.h>
#include <yarp/os/Stamp.h>
#include <yarp/os/Vocab.h>
Expand All @@ -33,8 +34,7 @@ struct PidControlTypeEnumHashFunction
}
};

struct JointProperties
{
struct CommonJointProperties {
std::string name;
yarp::dev::InteractionModeEnum interactionMode{yarp::dev::InteractionModeEnum::VOCAB_IM_STIFF};
yarp::conf::vocab32_t controlMode{VOCAB_CM_IDLE};
Expand All @@ -52,9 +52,19 @@ struct JointProperties
double velocity{0.0}; // Joint velocity [deg/s]
double velocityLimitMin{std::numeric_limits<double>::min()};
double velocityLimitMax{std::numeric_limits<double>::max()};
};

struct PhysicalJointProperties
{
CommonJointProperties commonJointProperties;
std::unordered_map<yarp::dev::PidControlTypeEnum, gz::math::PID, PidControlTypeEnumHashFunction>
pidControllers;
std::string positionControlLaw; // TODO: verify usefulness of this field
};

struct ActuatedAxisProperties
{
CommonJointProperties commonJointProperties;
std::unique_ptr<yarp::dev::gzyarp::TrajectoryGenerator> trajectoryGenerator;
double trajectoryGenerationRefPosition{0.0};
double trajectoryGenerationRefSpeed{0.0};
Expand All @@ -66,11 +76,18 @@ class ControlBoardData
{
public:
std::mutex mutex;
std::vector<JointProperties> joints;
std::vector<PhysicalJointProperties> physicalJoints;
std::vector<ActuatedAxisProperties> actuatedAxes;
yarp::os::Stamp simTime;

yarp::dev::IJointCoupling* ijointcoupling{nullptr};
xela-95 marked this conversation as resolved.
Show resolved Hide resolved
// TODO (xela95): read this value from configuration file
std::chrono::milliseconds controlUpdatePeriod = std::chrono::milliseconds(1);

bool initCoupledJoints();
bool setInteractionMode(int axis, yarp::dev::InteractionModeEnum mode);
bool setControlMode(int j, int mode);
private:
yarp::sig::VectorOf<size_t> coupledActuatedAxes, coupledPhysicalJoints;
};

class IControlBoardData
Expand Down
Loading