2022-02-24 17:57:56 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2022 ML!PA Consulting GmbH
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ingroup core_macros
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Math helper macros
|
|
|
|
*
|
|
|
|
* @author Benjamin Valentin <benjamin.valentin@ml-pa.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef MACROS_MATH_H
|
|
|
|
#define MACROS_MATH_H
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Returns the sign of @p a, either -1 or 1
|
|
|
|
*/
|
|
|
|
#define SIGNOF(a) _Generic(a, unsigned char: 1, \
|
|
|
|
unsigned short: 1, \
|
|
|
|
unsigned int: 1, \
|
|
|
|
unsigned long: 1, \
|
|
|
|
unsigned long long: 1, \
|
2022-11-04 22:50:53 +01:00
|
|
|
default: ((a) <= 0 ? ((a) == 0 ? 1L : -1L ): 1L))
|
2022-02-24 17:57:56 +01:00
|
|
|
/**
|
2022-11-09 17:50:01 +01:00
|
|
|
* @brief Calculates @p a/ @p b with arithmetic rounding (.5 away from zero)
|
2022-02-24 17:57:56 +01:00
|
|
|
*/
|
2022-11-09 17:50:01 +01:00
|
|
|
#define DIV_ROUND(a, b) ((SIGNOF(a) * ((SIGNOF(a) * (a)) + (SIGNOF(b) * (b)) / 2) / (b)))
|
2022-02-24 17:57:56 +01:00
|
|
|
|
|
|
|
/**
|
2022-11-09 17:50:01 +01:00
|
|
|
* @brief Calculates @p a/ @p b, always rounding up (towards positive infinity)
|
2022-02-24 17:57:56 +01:00
|
|
|
*/
|
2022-11-09 17:50:01 +01:00
|
|
|
#define DIV_ROUND_UP(a, b) ((SIGNOF(a)>0 && SIGNOF(b)>0) ? (((a) + (b) - 1) / (b)):\
|
|
|
|
(SIGNOF(a)<0 && SIGNOF(b)<0) ? (((a) + (b) + 1) / (b)): (a) / (b))
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Calculates @p a/ @p b, always rounding away from zero (towards positive and negative inf)
|
|
|
|
*/
|
|
|
|
#define DIV_ROUND_INF(a, b) (SIGNOF(a) * (((SIGNOF(a) * (a)) + (SIGNOF(b) * (b)) - 1) / (b)))
|
2022-02-24 17:57:56 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Align @p num with the next multiple of @p chunk
|
|
|
|
*/
|
2022-11-09 17:50:01 +01:00
|
|
|
#define MATH_ALIGN(num, chunk) ((chunk) * DIV_ROUND_INF(num, chunk))
|
2022-02-24 17:57:56 +01:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* MACROS_MATH_H */
|
|
|
|
/** @} */
|