primes.c 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. #include <u.h>
  2. #include <libc.h>
  3. #define ptsiz (sizeof(pt)/sizeof(pt[0]))
  4. #define whsiz (sizeof(wheel)/sizeof(wheel[0]))
  5. #define tabsiz (sizeof(table)/sizeof(table[0]))
  6. #define tsiz8 (tabsiz*8)
  7. double big = 9.007199254740992e15;
  8. int pt[] =
  9. {
  10. 2, 3, 5, 7, 11, 13, 17, 19, 23, 29,
  11. 31, 37, 41, 43, 47, 53, 59, 61, 67, 71,
  12. 73, 79, 83, 89, 97,101,103,107,109,113,
  13. 127,131,137,139,149,151,157,163,167,173,
  14. 179,181,191,193,197,199,211,223,227,229,
  15. };
  16. double wheel[] =
  17. {
  18. 10, 2, 4, 2, 4, 6, 2, 6, 4, 2,
  19. 4, 6, 6, 2, 6, 4, 2, 6, 4, 6,
  20. 8, 4, 2, 4, 2, 4, 8, 6, 4, 6,
  21. 2, 4, 6, 2, 6, 6, 4, 2, 4, 6,
  22. 2, 6, 4, 2, 4, 2,10, 2,
  23. };
  24. uchar table[1000];
  25. uchar bittab[] =
  26. {
  27. 1, 2, 4, 8, 16, 32, 64, 128,
  28. };
  29. void mark(double nn, long k);
  30. void ouch(void);
  31. void
  32. main(int argc, char *argp[])
  33. {
  34. int i;
  35. double k, temp, v, limit, nn;
  36. if(argc <= 1) {
  37. fprint(2, "usage: primes start [finish]\n");
  38. exits("usage");
  39. }
  40. nn = atof(argp[1]);
  41. limit = big;
  42. if(argc > 2) {
  43. limit = atof(argp[2]);
  44. if(limit < nn)
  45. exits(0);
  46. if(limit > big)
  47. ouch();
  48. }
  49. if(nn < 0 || nn > big)
  50. ouch();
  51. if(nn == 0)
  52. nn = 1;
  53. if(nn < 230) {
  54. for(i=0; i<ptsiz; i++) {
  55. if(pt[i] < nn)
  56. continue;
  57. if(pt[i] > limit)
  58. exits(0);
  59. print("%d\n", pt[i]);
  60. if(limit >= big)
  61. exits(0);
  62. }
  63. nn = 230;
  64. }
  65. modf(nn/2, &temp);
  66. nn = 2.*temp + 1;
  67. /*
  68. * clear the sieve table.
  69. */
  70. for(;;) {
  71. for(i=0; i<tabsiz; i++)
  72. table[i] = 0;
  73. /*
  74. * run the sieve.
  75. */
  76. v = sqrt(nn+tsiz8);
  77. mark(nn, 3);
  78. mark(nn, 5);
  79. mark(nn, 7);
  80. for(i=0,k=11; k<=v; k+=wheel[i]) {
  81. mark(nn, k);
  82. i++;
  83. if(i >= whsiz)
  84. i = 0;
  85. }
  86. /*
  87. * now get the primes from the table
  88. * and print them.
  89. */
  90. for(i=0; i<tsiz8; i+=2) {
  91. if(table[i>>3] & bittab[i&07])
  92. continue;
  93. temp = nn + i;
  94. if(temp > limit)
  95. exits(0);
  96. print("%.0f\n", temp);
  97. if(limit >= big)
  98. exits(0);
  99. }
  100. nn += tsiz8;
  101. }
  102. }
  103. void
  104. mark(double nn, long k)
  105. {
  106. double t1;
  107. long j;
  108. modf(nn/k, &t1);
  109. j = k*t1 - nn;
  110. if(j < 0)
  111. j += k;
  112. for(; j<tsiz8; j+=k)
  113. table[j>>3] |= bittab[j&07];
  114. }
  115. void
  116. ouch(void)
  117. {
  118. fprint(2, "limits exceeded\n");
  119. exits("limits");
  120. }