Infinite precision arithmetic has always been something that has fascinated me. This is an attempt to direct that fascination into something that might benefit other people too.
Arithmetica is a general-purpose infinite precision Linux and windows math library with a wide variety of mathematical functions and features. Currently supported languages are C, C++, and Python.
Using construct_regular_polygon.c, you can create and render polygons.
The code for this can be found after the usage section.
(Code)
If you're on or above Python 3.10, then pip will work for you. See below if not.
pip install arithmetica-py
Go to the project page on PyPi and download the built distributions. Use pip to install the .whl file as per your operating system.
Linux users are in luck! If you're on Linux, then you can automatically copy the '.a', '.so', '.h', and '.hpp' to /usr/include
with one command! Note that you will also need to install basic_math_operations: this can be done similarly.
curl -s -H "Accept: application/vnd.github.v3.raw" https://api.github.com/repos/avighnac/arithmetica/contents/install.sh | sudo bash
Include the header arithmetica.h and download the .a
file from the releases section.
#include "arithmetica.h"
// your code here
// ...
This library uses basic_math_operations for infinite precision arithmetic. To compile a program using arithmetica, do the following:
Download basic_math_operations in a similar manner. However, you do not have to include any headers for basic_math_operations. Use the following command to compile:
gcc/g++ filename.cpp/c [your arguments] -L. -larithmetica -lbasic_math_operations
Clone basic_math_operations and arithmetica using git
, or download the repositories. If your project is on GitHub, then use submodules to prevent cluttering your language statistics. In either case, the repositories should be present in your project's base folder (or any subfolders in that base folder).
In your base CMakeLists.txt
file, include the following lines of code:
# your previous CMake code here
# ...
# replace path_pointing_to_cloned_repo with the actual path
add_subdirectory(path_pointing_to_cloned_repo_arithmetica)
add_subdirectory(path_pointing_to_cloned_repo_basic_math_operations)
Then, in your CMakeLists.txt
responsible for compiling your executable, add these lines of code:
target_link_libraries(your_project_name_here PRIVATE arithmetica)
target_link_libraries(your_project_name_here PRIVATE basic_math_operations)
import arithmetica
print(arithmetica.arcsin('0.5', 20))
#include "arithmetica.h"
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int
main ()
{
char input[] = "0.5";
char *res = arcsin (input, 20); // 20 is the precision
printf ("%s%s%s", "arcsin(0.5) = ", res,
"\n"); // prints the inverse sine of 0.5
free (res);
return 0;
}
import matplotlib
matplotlib.use('Agg')
import matplotlib.pyplot as plt
from matplotlib.animation import FuncAnimation
import arithmetica
from PIL import Image
sides_init = 3
sides_max = 25
delay = 16 # in milliseconds
fig, ax = plt.subplots(figsize=(6, 6))
ax.set_aspect('equal')
polygon = arithmetica.construct_regular_polygon(sides_init, "1", 20)
polygon.append(("0", "0"))
x_coords = [float(pt[0]) for pt in polygon]
y_coords = [float(pt[1]) for pt in polygon]
line, = ax.plot(x_coords, y_coords)
def update(sides):
polygon = arithmetica.construct_regular_polygon(sides, "1", 20)
polygon.append(("0", "0"))
x_coords = [float(pt[0]) for pt in polygon]
y_coords = [float(pt[1]) for pt in polygon]
line.set_xdata(x_coords)
line.set_ydata(y_coords)
max_x = max(x_coords)
max_y = max(y_coords)
min_x = min(x_coords)
min_y = min(y_coords)
x_margin = 0.05 * (max_x - min_x)
y_margin = 0.05 * (max_y - min_y)
ax.set_xlim(min_x - x_margin, max_x + x_margin)
ax.set_ylim(min_y - y_margin, max_y + y_margin)
# Hide the spines and remove the ticks
ax.spines['top'].set_color('none')
ax.spines['right'].set_color('none')
ax.spines['bottom'].set_color('none')
ax.spines['left'].set_color('none')
ax.tick_params(axis='both', length=0, which='both')
ax.set_axis_off()
# Create a list of images for each frame of the animation
images = []
for sides in range(sides_init, sides_max+1):
update(sides)
fig.canvas.draw_idle()
fig.subplots_adjust
img = Image.frombytes('RGB', fig.canvas.get_width_height(),
fig.canvas.tostring_rgb())
images.append(img)
# Save the list of images as a GIF file
images[0].save('polygon.gif', save_all=True, append_images=images[1:], optimize=False, duration=delay, loop=0)
Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.
After making changes, please run the program's test suite by changing the ENABLE_TESTS
option to ON
, deleting the build/
folder, and recompiling.
Please make sure to update tests as appropriate.
Currently, arithmetica has the following decimal number functions:
arccos()
complex the inverse cosine of any number within the function's domain to any decimal place.arcsin()
computes the inverse sine of any number within the function's domain to any decimal place.arctan()
computes the inverse tangent of any number within the function's domain to any decimal place.continued_fraction_to_fraction()
converts a continued fraction to a non-negative rational fraction.cosine()
computes the cosine of an angle in radians to any decimal place.exponential()
computes e^x, where x is any real number to any decimal place.factorial()
computes the factorial of a non-negative integer.find_roots_of_polynomial()
finds the exact rational roots of a polynomial function.fraction_to_continued_fraction()
converts a non-negative rational fraction to a continued fraction.igcd()
computes the greatest common divisor of two non-negative integers.ilcm()
computes the least common multiple of two non-negative integers.natural_logarithm()
computes the natural logarithm of a positive number to any decimal place.power()
computes x^n, where x and n are rational numbers to any decimal place.repeating_decimal_to_fraction()
converts a repeating decimal to a fraction.simplify_arithmetic_expression()
simplifies an arithmetic expression involving the five basic math operations: addition, subtraction, multiplication, division, and exponentiation. This function can output either a decimal or fractional answer.sine()
computes the sine of an angle in radians to any decimal place.square_root()
computes the square root of a number to any decimal place.tangent()
computes the trignometric tangent of an angle in radians to any decimal place.terminating_decimal_to_fraction()
converts a terminating decimal to a fraction.
Arithmetica supports basic fraction arithmetic:
add_fraction()
adds two fractions.multiply_fraction()
multiplies two fractions.parse_fraction()
extracts a fraction from a string and/or converts a decimal to a fraction.power_fraction()
computes x^n, where x and n are fractions.subtract_fraction()
subtracts two fractions.
Arithmetica also has some complex number functions:
add_complex()
adds two complex numbers.divide_complex()
divides two complex numbers to any decimal place.exponential_complex()
computes e^(a + bi), where a + bi is a complex number to any decimal place.multiply_complex()
multiplies two complex numbers.square_root_complex()
finds the square root of a complex number to any decimal place.subtract_complex()
subtracts two complex numbers.