oh_my_loam/common/math/math_utils.cc

34 lines
732 B
C++

#include "math_utils.h"
#include "common/log/log.h"
namespace common {
double NormalizeAngle(double ang) {
const double &two_pi = 2 * M_PI;
return ang - two_pi * std::floor((ang + M_PI) / two_pi);
}
double Degree2Rad(double degree) {
return degree * M_PI / 180.0;
}
double Rad2Degree(double rad) {
return rad * 180.0 / M_PI;
}
const std::vector<int> Range(int begin, int end, int step) {
ACHECK(step != 0) << "Step must be non-zero";
int num = (end - begin) / step;
if (num <= 0) return {};
end = begin + step * num;
std::vector<int> seq(num);
for (int i = begin; i != end; i += step) seq[i] = i;
return seq;
}
const std::vector<int> Range(int end) {
return Range(0, end, 1);
}
} // namespace common