Advertisement
Guest User

Untitled

a guest
May 26th, 2019
94
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C 2.99 KB | None | 0 0
  1. #include <cuda.h>
  2. #include <curand_kernel.h>
  3. #include <stdio.h>
  4. #include <time.h>
  5. #include<stdio.h>
  6. #include<math.h>
  7. #include<time.h>
  8. #include<stdlib.h>
  9.  
  10. #define N 1000000
  11. #define n 3
  12.  
  13. __global__ void setup_kernel(curandState * state, unsigned long seed)
  14. {
  15.     int id = threadIdx.x;
  16.     curand_init(seed, id, 0, &state[id]);
  17. }
  18.  
  19. __global__ void generate(curandState* globalState, float* randomArray)
  20. {
  21.     int ind = threadIdx.x;
  22.     curandState localState = globalState[ind];
  23.     float RANDOM = curand_uniform(&localState);
  24.     randomArray[ind] = RANDOM;
  25.     globalState[ind] = localState;
  26. }
  27.  
  28. double f(double x[]) {
  29.     return x[0]*x[1]*x[2];
  30. }
  31.  
  32. float* r()
  33. {
  34.     dim3 tpb(N, 1, 1);
  35.     curandState* devStates;
  36.     float* randomValues = new float[N];
  37.     float* devRandomValues;
  38.  
  39.     cudaMalloc(&devStates, N * sizeof(curandState));
  40.     cudaMalloc(&devRandomValues, N * sizeof(*randomValues));// setup seeds
  41.     setup_kernel <<< 1, tpb >>> (devStates, time(NULL));
  42.  
  43.     //printf("%s\n", cudaGetErrorString(cudaGetLastError()));// generate random numbers
  44.     generate <<< 1, tpb >>> (devStates, devRandomValues);
  45.  
  46.     //printf("%s\n", cudaGetErrorString(cudaGetLastError()));
  47.  
  48.     cudaMemcpy(randomValues, devRandomValues, N * sizeof(*randomValues), cudaMemcpyDeviceToHost);
  49.    
  50.     //cudaFree(devRandomValues);
  51.     //cudaFree(devStates);
  52.  
  53.     return randomValues;
  54. }
  55.  
  56. void integral(int number_of_points, double m[]) {
  57.     srand(time(NULL));
  58.  
  59.  
  60.     int in = 0;
  61.     double k[n + 1];
  62.     float* rr = r();
  63.     for (int i = 0; i < number_of_points; i++)
  64.     {
  65.         printf("%d %lf \n", i, rr[i]);
  66.     }
  67.     for (int i = 0; i < number_of_points; i++)
  68.     {
  69.         for (int j = 0; j < n + 1; j++)
  70.         {
  71.             //double rr = (double)rand()/RAND_MAX;
  72.             //double rr = r[i];
  73.             k[j] = (m[2 * j + 1] - m[2 * j])*rr[i] + m[2 * j];
  74.             printf("%lf \n", rr[i]);
  75.  
  76.         }
  77.  
  78.         if (f(k) < k[n] && k[n] < 0)
  79.         {
  80.             printf("%d kek", in);
  81.             in--;
  82.         }
  83.         if (f(k) > k[n] && k[n] > 0)
  84.         {
  85.             printf("%d lol", in);
  86.             in++;
  87.         }
  88.     }
  89.  
  90.     double v = 1;
  91.     for (int i = 0; i < n + 1; i++)
  92.     {
  93.         v = v * (m[2 * i + 1] - m[2 * i]);
  94.     }
  95.     double real = 9176.7;
  96.     double result = v * in / (double) number_of_points;
  97.     printf(" result= %lf, error %lf\n ", result, fabs(result - real));
  98. }
  99.  
  100.  
  101.  
  102. int main(int argc, char** argv)
  103. {
  104.     //int n;
  105.     //printf("enter n: \n");
  106.     //scanf("%d", &n);
  107.  
  108.     double m[2 * (n + 1)];
  109.  
  110.     for (int i = 0; i < n; i++)
  111.     {
  112.         printf("enter min x[%d]: \n", i);
  113.         scanf("%lf", &m[2 * i]);
  114.  
  115.         printf("enter max x[%d]: \n", i);
  116.         scanf("%lf", &m[2 * i + 1]);
  117.     }
  118.  
  119.     for (int i = 1; i < 2; i++)
  120.     {
  121.         printf("enter min y: \n");
  122.         scanf("%lf", &m[2 * n]);
  123.  
  124.         printf("enter max y: \n");
  125.         scanf("%lf", &m[2 * n + i]);
  126.     }
  127.  
  128.     clock_t begin = clock();
  129.  
  130.     for (int number_of_points = 100; number_of_points < N; number_of_points *= 10) {
  131.         printf("For %d points\n", number_of_points);
  132.         integral(number_of_points, m);
  133.     }
  134.  
  135.  
  136.    
  137.     clock_t end = clock();
  138.     double t = (double)(end - begin) / CLOCKS_PER_SEC;
  139.     printf("%lf", t);
  140.     return 0;
  141. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement