36 #include <geometry_msgs/PoseArray.h> 37 #include <geometry_msgs/PoseWithCovarianceStamped.h> 39 #include <gtest/gtest.h> 43 inline geometry_msgs::PoseWithCovarianceStamped generatePoseWithCov(
44 const float y,
const float y_var,
const float var_measure = 0.0)
46 geometry_msgs::PoseWithCovarianceStamped pose;
47 pose.header.frame_id =
"map";
49 pose.pose.pose.position.y = y;
50 pose.pose.pose.orientation.w = 1.0;
51 pose.pose.covariance[6 * 0 + 0] = var_measure;
52 pose.pose.covariance[6 * 1 + 1] = y_var;
53 pose.pose.covariance[6 * 2 + 2] = var_measure;
54 pose.pose.covariance[6 * 3 + 3] = var_measure;
55 pose.pose.covariance[6 * 4 + 4] = var_measure;
56 pose.pose.covariance[6 * 5 + 5] = var_measure;
59 std::pair<float, float> getMean(
const std::vector<geometry_msgs::Pose>& poses)
62 for (
const geometry_msgs::Pose p : poses)
69 for (
const geometry_msgs::Pose p : poses)
71 root_mean += std::pow(p.position.y - mean, 2.0f);
73 root_mean /= poses.size();
75 return std::pair<float, float>(mean, root_mean);
78 TEST(Landmark, Measurement)
80 geometry_msgs::PoseArray::ConstPtr poses;
82 const boost::function<void(const geometry_msgs::PoseArray::ConstPtr&)> cb_pose =
83 [&poses](
const geometry_msgs::PoseArray::ConstPtr& msg) ->
void 91 nh.
advertise<geometry_msgs::PoseWithCovarianceStamped>(
"initialpose", 1,
true);
93 nh.
advertise<geometry_msgs::PoseWithCovarianceStamped>(
"mcl_measurement", 1,
true);
96 pub_init.
publish(generatePoseWithCov(2.0, 1.0));
100 ASSERT_TRUE(static_cast<bool>(poses));
101 for (
const geometry_msgs::Pose p : poses->poses)
103 ASSERT_FLOAT_EQ(p.position.x, 0.0f);
104 ASSERT_FLOAT_EQ(p.position.z, 0.0f);
105 ASSERT_FLOAT_EQ(p.orientation.x, 0.0f);
106 ASSERT_FLOAT_EQ(p.orientation.y, 0.0f);
107 ASSERT_FLOAT_EQ(p.orientation.z, 0.0f);
108 ASSERT_FLOAT_EQ(p.orientation.w, 1.0f);
110 const std::pair<float, float> mean_init = getMean(poses->poses);
111 ASSERT_NEAR(mean_init.first, 2.0f, 0.1f);
112 ASSERT_NEAR(mean_init.second, 1.0f, 0.1f);
115 pub_landmark.publish(generatePoseWithCov(2.6, 1.0, 1000.0));
119 ASSERT_TRUE(static_cast<bool>(poses));
120 for (
const geometry_msgs::Pose p : poses->poses)
122 ASSERT_FLOAT_EQ(p.position.x, 0.0f);
123 ASSERT_FLOAT_EQ(p.position.z, 0.0f);
124 ASSERT_FLOAT_EQ(p.orientation.x, 0.0f);
125 ASSERT_FLOAT_EQ(p.orientation.y, 0.0f);
126 ASSERT_FLOAT_EQ(p.orientation.z, 0.0f);
127 ASSERT_FLOAT_EQ(p.orientation.w, 1.0f);
129 const std::pair<float, float> mean_measured = getMean(poses->poses);
130 ASSERT_NEAR(mean_measured.first, 2.3f, 0.1f);
131 ASSERT_NEAR(mean_measured.second, 0.5f, 0.1f);
134 int main(
int argc,
char** argv)
136 testing::InitGoogleTest(&argc, argv);
139 return RUN_ALL_TESTS();
void publish(const boost::shared_ptr< M > &message) const
TEST(Landmark, Measurement)
Subscriber subscribe(const std::string &topic, uint32_t queue_size, void(T::*fp)(M), T *obj, const TransportHints &transport_hints=TransportHints())
ROSCPP_DECL void init(int &argc, char **argv, const std::string &name, uint32_t options=0)
Publisher advertise(const std::string &topic, uint32_t queue_size, bool latch=false)
ROSCPP_DECL void spinOnce()
int main(int argc, char **argv)