Storing numbers with higher precision in C

后端 未结 3 1488
[愿得一人]
[愿得一人] 2021-01-20 20:49

I am writing a program in which I need to store numbers with a very high precision(around 10^-10) and then further use them a parameter( create_bloomfilte

相关标签:
3条回答
  • 2021-01-20 21:22

    Is long double sufficient? Some implementations use 128bit long double, which should easily handle your requirements.

    http://en.wikipedia.org/wiki/Quadruple_precision

    If you're looking for something extremely strong, check out MPFR

    0 讨论(0)
  • 2021-01-20 21:30

    You have been misinformed about double.

    The smallest positive number you can store in a double is about 2⨯10-308, not counting denormalized numbers, which can be smaller. Denormals go down to 5⨯10-324. They have the equivalent of about 15-17 digits of precision, which is sufficient to measure the diameter of the Earth to within the size of a red blood cell, the smallest cell in the human body.

    If you really need more precision, you need MPFR. (If your algorithms are numerically unstable, MPFR might not help.)

    Edit: I figured out what you are doing wrong.

    In C, 10^-7 is an integer expression. It should be equal to -13 on most systems. The ^ operator is the bitwise XOR operator, not the exponentiation operator. There is no exponentiation operator in C, because C operators generally correspond to more primitive operations, at least in terms of hardware implementation.

    You want 1e-7, or pow(10, -7).

    #include <stdio.h>
    #include <math.h>
    int main(int argc, char *argv[])
    {
        printf("2e-308 = %g\n", 2e-308);
        printf("2 * pow(10, -308) = %g\n", 2 * pow(10, -308));
        printf("10^-7 = %d\n", 10^-7);
        return 0;
    }
    

    Output:

    2e-308 = 2e-308
    2 * pow(10, -308) = 2e-308
    10^-7 = -13
    

    Note that there are a lot of gotchas with floating point numbers.

    0 讨论(0)
  • 2021-01-20 21:41

    Try GNU MPFR library and GNU GMP library

    The MPFR library is a C library for multiple-precision floating-point computations with correct rounding.

    GMP is a free library for arbitrary precision arithmetic, operating on signed integers, rational numbers, and floating point numbers. There is no practical limit to the precision except the ones implied by the available memory in the machine GMP runs on. GMP has a rich set of functions, and the functions have a regular interface.

    0 讨论(0)
提交回复
热议问题