Skip to content

Commit

Permalink
Create abs, absDot and Corerct functions for Vector2d
Browse files Browse the repository at this point in the history
- Abs() => Get the absolute value of the vector
- AbsDot() => The absolute dot product
- Correct() => Corrects any nan values

Create unit test for all functions.

Did all checks and tests.

These functions intend to solve issue gazebosim#71

Signed-off-by: Felipe Ximenes <[email protected]>
  • Loading branch information
felximenes committed Jul 26, 2020
1 parent 0c34c7e commit d33b426
Show file tree
Hide file tree
Showing 2 changed files with 63 additions and 0 deletions.
32 changes: 32 additions & 0 deletions include/ignition/math/Vector2.hh
Original file line number Diff line number Diff line change
Expand Up @@ -108,6 +108,14 @@ namespace ignition
}
}

/// \brief Get the absolute value of the vector
/// \return a vector with positive elements
public: Vector2 Abs() const
{
return Vector2(std::abs(this->data[0]),
std::abs(this->data[1]));
}

/// \brief Returns a normalized vector
/// \return unit length vector
public: Vector2 Normalized() const
Expand All @@ -134,6 +142,30 @@ namespace ignition
return (this->data[0] * _v[0]) + (this->data[1] * _v[1]);
}

/// \brief Return the absolute dot product of this vector and
/// another vector. This is similar to the Dot function, except the
/// absolute value of each component of the vector is used.
///
/// result = abs(x1 * x2) + abs(y1 * y2)
///
/// \param[in] _v the vector
/// \return The absolute dot product
public: T AbsDot(const Vector2<T> &_v) const
{
return std::abs(this->data[0] * _v[0]) +
std::abs(this->data[1] * _v[1]);
}

/// \brief Corrects any nan values
public: inline void Correct()
{
// std::isfinite works with floating point values,
// need to explicit cast to avoid ambiguity in vc++.
if (!std::isfinite(static_cast<double>(this->data[0])))
this->data[0] = 0;
if (!std::isfinite(static_cast<double>(this->data[1])))
this->data[1] = 0;
}
/// \brief Assignment operator
/// \param[in] _v a value for x and y element
/// \return this
Expand Down
31 changes: 31 additions & 0 deletions src/Vector2_TEST.cc
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,10 @@ TEST(Vector2Test, Vector2)
v.Set(4, 5);
EXPECT_TRUE(v == math::Vector2d(4, 5));

// operator GetAbs
v.Set(-1, -2);
EXPECT_TRUE(v.Abs() == math::Vector2d(1, 2));

// ::operator=
v = math::Vector2d(6, 7);
EXPECT_TRUE(v == math::Vector2d(6, 7));
Expand Down Expand Up @@ -156,6 +160,22 @@ TEST(Vector2Test, TestNormalized)
EXPECT_EQ(vec3, math::Vector2d(0.447213, 0.894427));
}

//////////////////////////////////////////////
TEST(Vector2Test, Correct)
{
math::Vector2d vec1(0, NAN);
math::Vector2d vec2(INFINITY, -1);
math::Vector2d vec3(10, -2);

vec1.Correct();
vec2.Correct();
vec3.Correct();

EXPECT_EQ(vec1, math::Vector2d(0, 0));
EXPECT_EQ(vec2, math::Vector2d(0, -1));
EXPECT_EQ(vec3, math::Vector2d(10, -2));
}

/////////////////////////////////////////////////
TEST(Vector2Test, NoException)
{
Expand Down Expand Up @@ -189,6 +209,17 @@ TEST(Vector2Test, Dot)
EXPECT_DOUBLE_EQ(v.Dot(math::Vector2d(0, 1)), 2.0);
}

/////////////////////////////////////////////////
TEST(Vector2Test, AbsDot)
{
math::Vector2d v(1, -2);

EXPECT_DOUBLE_EQ(v.AbsDot(math::Vector2d(3, 4)), 11.0);
EXPECT_DOUBLE_EQ(v.AbsDot(math::Vector2d(0, 0)), 0.0);
EXPECT_DOUBLE_EQ(v.AbsDot(math::Vector2d(1, 0)), 1.0);
EXPECT_DOUBLE_EQ(v.AbsDot(math::Vector2d(0, 1)), 2.0);
}

/////////////////////////////////////////////////
TEST(Vector2Test, OperatorStreamOut)
{
Expand Down

0 comments on commit d33b426

Please sign in to comment.