1
1
mirror of https://github.com/theoludwig/libcproject.git synced 2024-11-14 16:03:13 +01:00
libcproject/lib/mathematics.h

126 lines
2.5 KiB
C
Raw Permalink Normal View History

#ifndef __LIBCPROJECT_MATHEMATICS__
#define __LIBCPROJECT_MATHEMATICS__
2023-01-05 19:28:05 +01:00
#define MATHEMATICS_FLOAT_PRECISION 0.00000001
#include <errno.h>
2023-01-05 19:28:05 +01:00
#include <stdbool.h>
#include <stdlib.h>
2023-01-05 19:28:05 +01:00
2023-06-25 15:07:34 +02:00
#include "types.h"
/**
* @brief Verify that 2 numbers are equal.
*
* @param number1
* @param number2
2023-08-09 21:08:15 +02:00
* @return true
* @return false
* @since v1.0.0
*/
2023-01-05 21:13:10 +01:00
bool mathematics_equals(const float number1, const float number2);
2023-01-05 19:28:05 +01:00
/**
* @brief Get the absolute value of a number.
*
* @param number
2023-08-09 21:08:15 +02:00
* @return unsigned long long
* @since v1.0.0
*/
2023-01-05 19:28:05 +01:00
unsigned long long mathematics_absolute_value(const long long number);
/**
* @brief Calculates the power of a number.
*
* @param base
* @param exponent
2023-08-09 21:08:15 +02:00
* @return unsigned long long
* @since v1.0.0
*/
2023-01-05 19:28:05 +01:00
unsigned long long mathematics_pow(unsigned long long base, unsigned long long exponent);
/**
2023-08-09 21:08:15 +02:00
* @brief Calculates the nth root of a number.
2023-01-05 19:28:05 +01:00
*
* @param number
* @param nth_root
2023-08-09 21:08:15 +02:00
* @return float
* @since v1.0.0
2023-01-05 19:28:05 +01:00
*/
float mathematics_root(float number, unsigned int nth_root);
/**
* @brief Calculates the square root of a number using Heron's method.
*
* @param number
2023-08-09 21:08:15 +02:00
* @return float
* @since v1.0.0
*/
2023-01-05 19:28:05 +01:00
float mathematics_square_root(float number);
/**
* @brief Calculates the factorial of a number.
*
* @param number
2023-08-09 21:08:15 +02:00
* @return unsigned long long
* @since v1.0.0
*/
2023-01-05 19:28:05 +01:00
unsigned long long mathematics_factorial(unsigned long long number);
2024-09-13 14:44:26 +02:00
/**
* @brief Calulcates the opposite number (additive inverse).
*
* @param number
* @return int64_t
*
* @code
* mathematics_opposite(7) // -7
*
* mathematics_opposite(-7) // 7
* @endcode
2024-09-15 18:43:39 +02:00
* @since v4.3.0
2024-09-13 14:44:26 +02:00
*/
int64_t mathematics_opposite(int64_t number);
/**
* @brief Returns the largest number between 2 numbers.
*
* @param number1
* @param number2
* @return int64_t
2024-09-15 18:43:39 +02:00
* @since v4.3.0
*/
int64_t mathematics_max(int64_t number1, int64_t number2);
/**
* @brief Returns the largest number between multiple numbers. If the array is empty, returns 0.
*
* @param values
* @param values_length
* @return int64_t
2024-09-15 18:43:39 +02:00
* @since v4.3.0
*/
int64_t mathematics_max_values(int64_t *values, size_t values_length);
/**
* @brief Returns the smallest number between 2 numbers.
*
* @param number1
* @param number2
* @return int64_t
2024-09-15 18:43:39 +02:00
* @since v4.3.0
*/
int64_t mathematics_min(int64_t number1, int64_t number2);
/**
* @brief Returns the smallest number between multiple numbers. If the array is empty, returns 0.
*
* @param values
* @param values_length
* @return int64_t
2024-09-15 18:43:39 +02:00
* @since v4.3.0
*/
int64_t mathematics_min_values(int64_t *values, size_t values_length);
2023-01-05 19:28:05 +01:00
#endif