6 PidObject::PidObject() : error_(3, 0), filtered_error_(3, 0), error_deriv_(3, 0), filtered_error_deriv_(3, 0)
13 ROS_INFO(
"controller spinning, waiting for time to become non-zero");
19 node_priv.
param<
double>(
"Kp",
Kp_, 1.0);
20 node_priv.
param<
double>(
"Ki",
Ki_, 0.0);
21 node_priv.
param<
double>(
"Kd",
Kd_, 0.0);
35 "setpoint_timeout set to %.2f but needs to -1 or >0", setpoint_timeout_);
44 std::cout <<
"Error: invalid parameter\n";
54 if (!plant_sub_ || !setpoint_sub_ || !pid_enabled_sub_)
62 dynamic_reconfigure::Server<pid::PidConfig> config_server;
63 dynamic_reconfigure::Server<pid::PidConfig>::CallbackType
f;
65 config_server.setCallback(f);
68 while(
ros::ok() && !ros::topic::waitForMessage<std_msgs::Float64>(setpoint_topic_,
ros::Duration(10.)))
71 while(
ros::ok() && !ros::topic::waitForMessage<std_msgs::Float64>(topic_from_plant_,
ros::Duration(10.)))
108 while (
ros::ok() && ((fabs(value) > 1.0 || fabs(value) < 0.1) && (digits < 2 && digits > -1)))
110 if (fabs(value) > 1.0)
126 scale = pow(10.0, digits);
133 ROS_ERROR(
"The lower saturation limit cannot be greater than the upper " 134 "saturation limit.");
143 std::cout << std::endl <<
"PID PARAMETERS" << std::endl <<
"-----------------------------------------" << std::endl;
144 std::cout <<
"Kp: " <<
Kp_ <<
", Ki: " <<
Ki_ <<
", Kd: " <<
Kd_ << std::endl;
146 std::cout <<
"LPF cutoff frequency: 1/4 of sampling rate" << std::endl;
152 std::cout <<
"Name of setpoint topic: " <<
setpoint_topic_ << std::endl;
153 std::cout <<
"Integral-windup limit: " <<
windup_limit_ << std::endl;
155 std::cout <<
"-----------------------------------------" << std::endl;
182 if (!((
Kp_ <= 0. &&
Ki_ <= 0. &&
Kd_ <= 0.) ||
184 ROS_WARN(
"All three gains (Kp, Ki, Kd) should have the same sign for " 229 ROS_ERROR(
"delta_t is 0, skipping this loop. Possible overloaded cpu " 237 ROS_INFO(
"prev_time is 0, doing nothing");
285 (1 / (1 +
c_ *
c_ + 1.414 *
c_)) *
309 std_msgs::Float64MultiArray pidDebugMsg;
310 pidDebugMsg.data = pid_debug_vect;
315 ROS_WARN_ONCE(
"Setpoint message timed out, will stop publising control_effort_messages");
316 error_integral_ = 0.0;
319 error_integral_ = 0.0;
std::string topic_from_controller_
std::vector< double > filtered_error_deriv_
ros::Publisher control_effort_pub_
std::string pid_debug_pub_name_
void publish(const boost::shared_ptr< M > &message) const
double max_loop_frequency_
Subscriber subscribe(const std::string &topic, uint32_t queue_size, void(T::*fp)(M), T *obj, const TransportHints &transport_hints=TransportHints())
std::vector< double > error_deriv_
ROSCPP_DECL const std::string & getName()
double min_loop_frequency_
std::string topic_from_plant_
std::string pid_enable_topic_
std::string setpoint_topic_
bool validateParameters()
#define ROS_WARN_ONCE(...)
void reconfigureCallback(pid::PidConfig &config, uint32_t level)
bool param(const std::string ¶m_name, T ¶m_val, const T &default_val) const
#define ROS_ASSERT_MSG(cond,...)
ros::Publisher pid_debug_pub_
Publisher advertise(const std::string &topic, uint32_t queue_size, bool latch=false)
#define ROS_WARN_STREAM(args)
ros::Time last_setpoint_msg_time_
std::vector< double > filtered_error_
void pidEnableCallback(const std_msgs::Bool &pid_enable_msg)
void setpointCallback(const std_msgs::Float64 &setpoint_msg)
std_msgs::Float64 control_msg_
ROSCPP_DECL void shutdown()
#define ROS_ERROR_STREAM(args)
ROSCPP_DECL void spinOnce()
void getParams(double in, double &value, double &scale)
void plantStateCallback(const std_msgs::Float64 &state_msg)
std::vector< double > error_