Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • Home
  • SEARCH
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 167927
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 11, 20262026-05-11T12:21:44+00:00 2026-05-11T12:21:44+00:00

I want to know the first double from 0d upwards that deviates by the

  • 0

I want to know the first double from 0d upwards that deviates by the long of the ‘same value’ by some delta, say 1e-8. I’m failing here though. I’m trying to do this in C although I usually use managed languages, just in case. Please help.

 #include <stdio.h> #include <limits.h> #define DELTA 1e-8  int main() {     double d = 0; // checked, the literal is fine     long i;     for (i = 0L; i < LONG_MAX; i++) {          d=i; // gcc does the cast right, i checked          if (d-i > DELTA || d-i < -DELTA) {               printf('%f', d);               break;          }     } }

I’m guessing that the issue is that d-i casts i to double and therefore d==i and then the difference is always 0. How else can I detect this properly — I’d prefer fun C casting over comparing strings, which would take forever.

ANSWER: is exactly as we expected. 2^53+1 = 9007199254740993 is the first point of difference according to standard C/UNIX/POSIX tools. Thanks much to pax for his program. And I guess mathematics wins again.

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. 2026-05-11T12:21:45+00:00Added an answer on May 11, 2026 at 12:21 pm

    Doubles in IEE-754 have a precision of 52 bits which means they can store numbers accurately up to (at least) 251.

    If your longs are 32-bit, they will only have the (positive) range 0 .. 231 - 1 so there is no 32-bit long that cannot be represented exactly as a double. For a 64-bit long, it will be (roughly) 252 so I’d be starting around there, not at zero.

    You can use the following program to detect where the failures start to occur. An earlier version I had relied on the fact that the last digit in a number that continuously doubles follows the sequence {2,4,8,6}. However, I opted eventually to use a known trusted tool (bc) for checking the whole number, not just the last digit.

    Keep in mind that this may be affected by the actions of sprintf() rather than the real accuracy of doubles (I don’t think so personally since it had no troubles with certain numbers up to 2143).

    This is the test program I wrote:

    #include <stdio.h> #include <stdlib.h> #include <string.h>  int main() {     FILE *fin;     double d = 3.0; // 2^n + 1 to avoid exact powers of 2.     int i = 1;     char ds[1000];     char tst[1000];      // Loop forever, rely on break to finish.      while (1) {         // Get C version of the double.          sprintf (ds, "%.0f", d);          // Get bc version of the double.          sprintf (tst, "echo '2^%d - 1' | bc >tmpfile", i);         system(tst);         fin = fopen ("tmpfile", "r");         fgets (tst, sizeof (tst), fin);         fclose (fin);         tst[strlen (tst) - 1] = '\0';          // Check them.          if (strcmp (ds, tst) != 0) {             printf( "2^%d + 1 <-- bc failure\n", i);             printf( "   got       [%s]\n", ds);             printf( "   expected  [%s]\n", tst);             break;         }          // Output for status then move to next.          printf( "2^%d + 1 = %s\n", i, ds);         d = (d - 1) * 2 + 1;  // Again, 2^n + 1.         i++;     } } 

    This keeps going until:

    2^49 + 1 = 562949953421313 2^50 + 1 = 1125899906842625 2^51 + 1 = 2251799813685249 2^52 + 1 = 4503599627370497 2^53 + 1 <-- bc failure    got       [9007199254740992]    expected  [9007199254740993] 

    which is roughly about where I’d expect it to fail.

    As an aside, I originally used numbers of the form 2n but that got me all the way up to:

    2^136 = 87112285931760246646623899502532662132736 2^137 = 174224571863520493293247799005065324265472 2^138 = 348449143727040986586495598010130648530944 2^139 = 696898287454081973172991196020261297061888 2^140 = 1393796574908163946345982392040522594123776 2^141 = 2787593149816327892691964784081045188247552 2^142 = 5575186299632655785383929568162090376495104 2^143 <-- bc failure    got       [11150372599265311570767859136324180752990210]    expected  [11150372599265311570767859136324180752990208] 

    with the size of a double being 8 bytes (checked with sizeof). It turned out these numbers were of the binary form 1000...000, which can be represented for far longer with doubles. That’s when I switched to using 2n + 1 to get a better bit pattern (one at the start and one at the end).


    Now, just to be clear, the most reliable way would be to check every number to see which one fails first, but that’s going to have quite a long runtime. This approach is the best one given knowledge of the IEEE-754 encodings.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Ask A Question

Stats

  • Questions 93k
  • Answers 93k
  • Best Answers 0
  • User 1
  • Popular
  • Answers
  • Editorial Team

    How to approach applying for a job at a company ...

    • 7 Answers
  • Editorial Team

    How to handle personal stress caused by utterly incompetent and ...

    • 5 Answers
  • Editorial Team

    What is a programmer’s life like?

    • 5 Answers
  • Editorial Team
    Editorial Team added an answer (void)initialize is the NSObject's method You can find it in… May 11, 2026 at 6:41 pm
  • Editorial Team
    Editorial Team added an answer Here's a way to repeat the items. In your page… May 11, 2026 at 6:41 pm
  • Editorial Team
    Editorial Team added an answer WMI can sometimes be interesting to work with...I think I… May 11, 2026 at 6:41 pm

Related Questions

I have an text that consists of information enclosed by a certain pattern. The
I'm trying to read data in from a binary file and then store in
So I've been working on this all day and I can't figure out how
I want to create an assembly using IronPython can call it from C#. Here

Trending Tags

analytics british company computer developers django employee employer english facebook french google interview javascript language life php programmer programs salary

Top Members

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.