31 #ifndef HOMEGEARMATH_H_ 32 #define HOMEGEARMATH_H_ 58 std::string
toString() {
return std::to_string(
x) +
';' + std::to_string(
y); }
80 std::string
toString() {
return std::to_string(
x) +
';' + std::to_string(
y) +
';' + std::to_string(z); }
117 double determinant();
185 double distance(
const Point2D &p,
Point2D *closestPoint =
nullptr);
207 static bool isNumber(
const std::string &s,
bool hex =
false);
222 static int32_t
getNumber(
const std::string &s,
bool isHex =
false);
236 static int64_t
getNumber64(
const std::string &s,
bool isHex =
false);
332 static double getDouble(
const std::string &s);
340 static std::string
toString(
double number);
349 static std::string
toString(
double number, int32_t precision);
359 static int32_t
clamp(int32_t
value, int32_t min, int32_t max);
369 static double clamp(
double value,
double min,
double max);
381 static int32_t
scale(int32_t
value, int32_t valueMin, int32_t valueMax, int32_t scaleMin, int32_t scaleMax);
393 static double scale(
double value,
double valueMin,
double valueMax,
double scaleMin,
double scaleMax);
398 static inline double Pow10(int32_t exponent) {
399 static const double e[] =
402 1e+1, 1e+2, 1e+3, 1e+4, 1e+5, 1e+6, 1e+7, 1e+8, 1e+9, 1e+10, 1e+11, 1e+12, 1e+13, 1e+14, 1e+15, 1e+16, 1e+17, 1e+18, 1e+19, 1e+20,
403 1e+21, 1e+22, 1e+23, 1e+24, 1e+25, 1e+26, 1e+27, 1e+28, 1e+29, 1e+30, 1e+31, 1e+32, 1e+33, 1e+34, 1e+35, 1e+36, 1e+37, 1e+38, 1e+39, 1e+40,
404 1e+41, 1e+42, 1e+43, 1e+44, 1e+45, 1e+46, 1e+47, 1e+48, 1e+49, 1e+50, 1e+51, 1e+52, 1e+53, 1e+54, 1e+55, 1e+56, 1e+57, 1e+58, 1e+59, 1e+60,
405 1e+61, 1e+62, 1e+63, 1e+64, 1e+65, 1e+66, 1e+67, 1e+68, 1e+69, 1e+70, 1e+71, 1e+72, 1e+73, 1e+74, 1e+75, 1e+76, 1e+77, 1e+78, 1e+79, 1e+80,
406 1e+81, 1e+82, 1e+83, 1e+84, 1e+85, 1e+86, 1e+87, 1e+88, 1e+89, 1e+90, 1e+91, 1e+92, 1e+93, 1e+94, 1e+95, 1e+96, 1e+97, 1e+98, 1e+99, 1e+100,
407 1e+101, 1e+102, 1e+103, 1e+104, 1e+105, 1e+106, 1e+107, 1e+108, 1e+109, 1e+110, 1e+111, 1e+112, 1e+113, 1e+114, 1e+115, 1e+116, 1e+117, 1e+118, 1e+119, 1e+120,
408 1e+121, 1e+122, 1e+123, 1e+124, 1e+125, 1e+126, 1e+127, 1e+128, 1e+129, 1e+130, 1e+131, 1e+132, 1e+133, 1e+134, 1e+135, 1e+136, 1e+137, 1e+138, 1e+139, 1e+140,
409 1e+141, 1e+142, 1e+143, 1e+144, 1e+145, 1e+146, 1e+147, 1e+148, 1e+149, 1e+150, 1e+151, 1e+152, 1e+153, 1e+154, 1e+155, 1e+156, 1e+157, 1e+158, 1e+159, 1e+160,
410 1e+161, 1e+162, 1e+163, 1e+164, 1e+165, 1e+166, 1e+167, 1e+168, 1e+169, 1e+170, 1e+171, 1e+172, 1e+173, 1e+174, 1e+175, 1e+176, 1e+177, 1e+178, 1e+179, 1e+180,
411 1e+181, 1e+182, 1e+183, 1e+184, 1e+185, 1e+186, 1e+187, 1e+188, 1e+189, 1e+190, 1e+191, 1e+192, 1e+193, 1e+194, 1e+195, 1e+196, 1e+197, 1e+198, 1e+199, 1e+200,
412 1e+201, 1e+202, 1e+203, 1e+204, 1e+205, 1e+206, 1e+207, 1e+208, 1e+209, 1e+210, 1e+211, 1e+212, 1e+213, 1e+214, 1e+215, 1e+216, 1e+217, 1e+218, 1e+219, 1e+220,
413 1e+221, 1e+222, 1e+223, 1e+224, 1e+225, 1e+226, 1e+227, 1e+228, 1e+229, 1e+230, 1e+231, 1e+232, 1e+233, 1e+234, 1e+235, 1e+236, 1e+237, 1e+238, 1e+239, 1e+240,
414 1e+241, 1e+242, 1e+243, 1e+244, 1e+245, 1e+246, 1e+247, 1e+248, 1e+249, 1e+250, 1e+251, 1e+252, 1e+253, 1e+254, 1e+255, 1e+256, 1e+257, 1e+258, 1e+259, 1e+260,
415 1e+261, 1e+262, 1e+263, 1e+264, 1e+265, 1e+266, 1e+267, 1e+268, 1e+269, 1e+270, 1e+271, 1e+272, 1e+273, 1e+274, 1e+275, 1e+276, 1e+277, 1e+278, 1e+279, 1e+280,
416 1e+281, 1e+282, 1e+283, 1e+284, 1e+285, 1e+286, 1e+287, 1e+288, 1e+289, 1e+290, 1e+291, 1e+292, 1e+293, 1e+294, 1e+295, 1e+296, 1e+297, 1e+298, 1e+299, 1e+300,
417 1e+301, 1e+302, 1e+303, 1e+304, 1e+305, 1e+306, 1e+307, 1e+308
static double getDouble(const std::string &s)
Converts a string to double.
Definition: Math.cpp:269
Point3D()
Definition: Math.h:68
Class defining a point in 2D space with numbers of type double.
Definition: Math.h:45
Point2D _b
Definition: Math.h:188
static uint32_t getUnsignedNumber(const std::string &s, bool isHex=false)
Converts a string (decimal or hexadecimal) to an unsigned integer.
Definition: Math.cpp:247
Class defining a line.
Definition: Math.h:125
void setA(Point2D value)
Definition: Math.h:135
static double Pow10(int32_t exponent)
Calculates powers to the base 10.
Definition: Math.h:398
void setB(Point2D &value)
Definition: Math.h:171
virtual ~Matrix3x3()
Definition: Math.h:106
static int32_t getNumber(const std::string &s, bool isHex=false)
Converts a string (decimal or hexadecimal) to an integer.
Definition: Math.cpp:226
Line()
Definition: Math.h:127
Line(const Point2D &a, const Point2D &b)
Definition: Math.h:128
void setA(Point2D &value)
Definition: Math.h:136
Point2D getB() const
Definition: Math.h:169
static int32_t clamp(int32_t value, int32_t min, int32_t max)
Forces a value between 'min' and 'max'.
Definition: Math.cpp:395
Definition: BaseLib.cpp:34
Class defining a triangle.
Definition: Math.h:156
double x
Definition: Math.h:60
Point2D _a
Definition: Math.h:187
void setA(Point2D value)
Definition: Math.h:167
Class defining a 3x3 matrix.
Definition: Math.h:92
static const std::array< int32_t, 23 > _asciiToBinaryTable
Map to faster convert hexadecimal numbers.
Definition: Math.h:436
static double getDoubleFromIeee754Binary64(uint64_t binary64)
Definition: Math.cpp:361
void setA(Point2D &value)
Definition: Math.h:168
static int32_t getOctalNumber(const std::string &s)
Converts a octal string to an integer.
Definition: Math.cpp:263
static int64_t getNumber64(const std::string &s, bool isHex=false)
Converts a string (decimal or hexadecimal) to an 64-bit integer.
Definition: Math.cpp:235
Point2D getB() const
Definition: Math.h:137
virtual ~Point3D()
Definition: Math.h:78
std::string toString()
Definition: Math.h:58
PVariable value
Definition: UiElements.h:217
Point2D()
Definition: Math.h:47
void setB(Point2D value)
Definition: Math.h:138
Point2D getA() const
Definition: Math.h:134
Triangle(const Point2D &a, const Point2D &b, const Point2D &c)
Definition: Math.h:159
Matrix3x3()
Definition: Math.h:104
static float getFloatFromIeee754Binary32(uint32_t binary32)
Definition: Math.cpp:351
void setB(Point2D &value)
Definition: Math.h:139
Point2D getA() const
Definition: Math.h:166
Point2D Vector2D
Definition: Math.h:64
virtual ~Triangle()
Definition: Math.h:164
Point2D _a
Definition: Math.h:149
static bool isNumber(const std::string &s, bool hex=false)
Checks if a string is a number.
Definition: Math.cpp:213
double y
Definition: Math.h:61
static uint64_t getIeee754Binary64(double value)
Definition: Math.cpp:313
void setC(Point2D &value)
Definition: Math.h:174
Point2D(double x, double y)
Definition: Math.h:52
static double metricExponentialMovingAverage(double interval, double period, double metric, double lastAverage)
Calculates the exponential moving average per time for performance metrics.
Definition: Math.cpp:421
Point3D Vector3D
Definition: Math.h:87
static uint64_t getUnsignedNumber64(const std::string &s, bool isHex=false)
Converts a string (decimal or hexadecimal) to an unsigned integer.
Definition: Math.cpp:255
~Math()=default
Destructor.
Point2D getC() const
Definition: Math.h:172
Point2D _c
Definition: Math.h:189
static uint32_t getIeee754Binary32(float value)
Definition: Math.cpp:275
void setC(Point2D value)
Definition: Math.h:173
static int32_t scale(int32_t value, int32_t valueMin, int32_t valueMax, int32_t scaleMin, int32_t scaleMax)
Scales 'value' between 'valueMin' and 'valueMax' to 'scaleMin' and 'scaleMax'.
Definition: Math.cpp:407
virtual ~Point2D()
Definition: Math.h:56
Triangle()
Definition: Math.h:158
virtual ~Line()
Definition: Math.h:132
std::string toString()
Definition: Math.h:80
void setB(Point2D value)
Definition: Math.h:170
Point2D _b
Definition: Math.h:150
Point3D(double x, double y, double z)
Definition: Math.h:73