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