mirror of
https://codeberg.org/comaps/comaps
synced 2025-12-20 13:23:59 +00:00
committed by
Konstantin Pastbin
parent
c9cbb64f12
commit
76ffc99abd
48
libs/geometry/angles.cpp
Normal file
48
libs/geometry/angles.cpp
Normal file
@@ -0,0 +1,48 @@
|
||||
#include "geometry/angles.hpp"
|
||||
|
||||
namespace ang
|
||||
{
|
||||
double AngleIn2PI(double ang)
|
||||
{
|
||||
double constexpr period = 2.0 * math::pi;
|
||||
ang = fmod(ang, period);
|
||||
if (ang < 0.0)
|
||||
ang += period;
|
||||
|
||||
if (AlmostEqualULPs(period, ang))
|
||||
return 0.0;
|
||||
|
||||
return ang;
|
||||
}
|
||||
|
||||
double GetShortestDistance(double rad1, double rad2)
|
||||
{
|
||||
double constexpr period = 2.0 * math::pi;
|
||||
rad1 = fmod(rad1, period);
|
||||
rad2 = fmod(rad2, period);
|
||||
|
||||
double res = rad2 - rad1;
|
||||
if (fabs(res) > math::pi)
|
||||
{
|
||||
if (res < 0.0)
|
||||
res = period + res;
|
||||
else
|
||||
res = -period + res;
|
||||
}
|
||||
return res;
|
||||
}
|
||||
|
||||
double GetMiddleAngle(double a1, double a2)
|
||||
{
|
||||
double ang = (a1 + a2) / 2.0;
|
||||
|
||||
if (fabs(a1 - a2) > math::pi)
|
||||
{
|
||||
if (ang > 0.0)
|
||||
ang -= math::pi;
|
||||
else
|
||||
ang += math::pi;
|
||||
}
|
||||
return ang;
|
||||
}
|
||||
} // namespace ang
|
||||
Reference in New Issue
Block a user