2017-09-11 13:27:23 +02:00
|
|
|
/** @file
|
|
|
|
* @author Edouard DUPIN
|
|
|
|
* @copyright 2017, Edouard DUPIN, all right reserved
|
|
|
|
* @license MPL v2.0 (see license file)
|
|
|
|
*/
|
|
|
|
#pragma once
|
2018-09-13 23:09:52 +02:00
|
|
|
#include <etk/types.hpp>
|
|
|
|
extern "C" {
|
|
|
|
#include <math.h>
|
|
|
|
}
|
2013-12-28 09:27:29 +01:00
|
|
|
|
2017-09-11 13:27:23 +02:00
|
|
|
namespace etk {
|
2017-09-14 00:59:21 +02:00
|
|
|
inline float cos(float _value) {
|
|
|
|
return ::cosf(_value);
|
|
|
|
}
|
|
|
|
inline float sin(float _value) {
|
|
|
|
return ::sinf(_value);
|
|
|
|
}
|
|
|
|
inline float tan(float _value) {
|
|
|
|
return ::tanf(_value);
|
|
|
|
}
|
|
|
|
inline float acos(float _value) {
|
|
|
|
return ::acosf(_value);
|
|
|
|
}
|
|
|
|
inline float asin(float _value) {
|
|
|
|
return ::asinf(_value);
|
|
|
|
}
|
|
|
|
inline float atan(float _value) {
|
|
|
|
return ::atanf(_value);
|
|
|
|
}
|
2017-10-02 23:26:11 +02:00
|
|
|
inline float atan2(float _value, float _value2) {
|
|
|
|
return ::atan2f(_value, _value2);
|
|
|
|
}
|
2017-09-14 00:59:21 +02:00
|
|
|
inline float sqrt(float _value) {
|
|
|
|
return ::sqrtf(_value);
|
|
|
|
}
|
2017-09-20 01:10:57 +02:00
|
|
|
inline float pow(float _xxx, float _yyy) {
|
|
|
|
return ::powf(_xxx, _yyy);
|
|
|
|
}
|
|
|
|
inline float log(float _value) {
|
|
|
|
return ::logf(_value);
|
|
|
|
}
|
|
|
|
inline float log10(float _value) {
|
|
|
|
return ::log10f(_value);
|
|
|
|
}
|
|
|
|
inline float exp(float _value) {
|
|
|
|
return ::expf(_value);
|
|
|
|
}
|
|
|
|
|
2017-09-14 00:59:21 +02:00
|
|
|
inline double cos(double _value) {
|
|
|
|
return ::cos(_value);
|
|
|
|
}
|
|
|
|
inline double sin(double _value) {
|
|
|
|
return ::sin(_value);
|
|
|
|
}
|
|
|
|
inline double tan(double _value) {
|
|
|
|
return ::tan(_value);
|
|
|
|
}
|
|
|
|
inline double acos(double _value) {
|
|
|
|
return ::acos(_value);
|
|
|
|
}
|
|
|
|
inline double asin(double _value) {
|
|
|
|
return ::asin(_value);
|
|
|
|
}
|
|
|
|
inline double atan(double _value) {
|
|
|
|
return ::atan(_value);
|
|
|
|
}
|
2017-10-02 23:26:11 +02:00
|
|
|
inline double atan2(double _value, double _value2) {
|
|
|
|
return ::atan2(_value, _value2);
|
|
|
|
}
|
2017-09-14 00:59:21 +02:00
|
|
|
inline double sqrt(double _value) {
|
|
|
|
return ::sqrt(_value);
|
|
|
|
}
|
2017-09-20 01:10:57 +02:00
|
|
|
inline double pow(double _xxx, double _yyy) {
|
|
|
|
return ::pow(_xxx, _yyy);
|
|
|
|
}
|
|
|
|
inline double log(double _value) {
|
|
|
|
return ::log(_value);
|
|
|
|
}
|
|
|
|
inline double log10(double _value) {
|
|
|
|
return ::log10(_value);
|
|
|
|
}
|
|
|
|
inline double exp(double _value) {
|
|
|
|
return ::exp(_value);
|
|
|
|
}
|
2017-09-11 13:27:23 +02:00
|
|
|
template <class TYPE> const TYPE& min(const TYPE& _val1, const TYPE& _val2) {
|
|
|
|
return (_val1 > _val2) ? _val2 : _val1;
|
|
|
|
}
|
|
|
|
template <class TYPE> const TYPE& max(const TYPE& _val1, const TYPE& _val2) {
|
|
|
|
return (_val1 > _val2) ? _val1 : _val2;
|
|
|
|
}
|
2017-09-14 00:59:21 +02:00
|
|
|
template <class TYPE> TYPE abs(const TYPE& _value) {
|
|
|
|
return (_value >= 0) ? _value : -_value;
|
|
|
|
}
|
2017-09-11 13:27:23 +02:00
|
|
|
/**
|
|
|
|
* @brief in std, we have min, max but not avg ==> it is missing... the Define of avg template.
|
|
|
|
* @param[in] _min Minimum value of the range
|
|
|
|
* @param[in] _val The value that we want a min/max
|
|
|
|
* @param[in] _max Maximum value of the range
|
|
|
|
* @return Value that min/max applied
|
|
|
|
*/
|
|
|
|
template <class TYPE> const TYPE& avg(const TYPE& _min, const TYPE& _val, const TYPE& _max) {
|
|
|
|
return etk::min(etk::max(_min,_val),_max);
|
|
|
|
}
|
|
|
|
template<class ETK_ITERATOR_TYPE>
|
|
|
|
size_t distance(const ETK_ITERATOR_TYPE& _start, const ETK_ITERATOR_TYPE& _stop) {
|
|
|
|
size_t out = 0;
|
|
|
|
ETK_ITERATOR_TYPE tmp = _start;
|
2017-09-20 01:10:57 +02:00
|
|
|
ETK_ITERATOR_TYPE tmp2 = _stop;
|
|
|
|
while (tmp != tmp2) {
|
2017-09-11 13:27:23 +02:00
|
|
|
out++;
|
|
|
|
++tmp;
|
|
|
|
}
|
|
|
|
return out;
|
|
|
|
}
|
2017-09-14 00:59:21 +02:00
|
|
|
template<class ETK_ITERATOR_TYPE_1, class ETK_ITERATOR_TYPE_2>
|
|
|
|
ETK_ITERATOR_TYPE_1 find(ETK_ITERATOR_TYPE_1 _start, ETK_ITERATOR_TYPE_1 _stop, const ETK_ITERATOR_TYPE_2& _value) {
|
|
|
|
while (_start != _stop) {
|
|
|
|
if (*_start == _value) {
|
|
|
|
return _start;
|
|
|
|
}
|
|
|
|
++_start;
|
|
|
|
}
|
|
|
|
return _stop;
|
|
|
|
}
|
2017-09-11 13:27:23 +02:00
|
|
|
}
|