ctest1088.c 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <sys/time.h>
  4. void kernel_cpu(int *A0,int *A1,int *A2,int *A3,int *A4,int *A5,int *A6,int *A7,float *B0,float *B1,float *B2,float *B3,float *B4,int N){
  5. for(int i=0;i<N;i++){
  6. A0[i] = A6[i];
  7. A1[i] = A7[i]*A7[i]*A7[i];
  8. A2[i] = A7[i]/A6[i];
  9. A3[i] = A7[i]+A5[i]/A7[i]/A6[i];
  10. A4[i] = A6[i]-A6[i]-A5[i]/A7[i];
  11. B0[i] = B3[i]/B3[i];
  12. }
  13. }
  14. int main(int argc,char **argv) {
  15. int size=924392;
  16. int intBytes = size*sizeof(int);
  17. int floatBytes = size*sizeof(float);
  18. int *A0;
  19. A0 = (int *)malloc(intBytes);
  20. int *A1;
  21. A1 = (int *)malloc(intBytes);
  22. int *A2;
  23. A2 = (int *)malloc(intBytes);
  24. int *A3;
  25. A3 = (int *)malloc(intBytes);
  26. int *A4;
  27. A4 = (int *)malloc(intBytes);
  28. int *A5;
  29. A5 = (int *)malloc(intBytes);
  30. int *A6;
  31. A6 = (int *)malloc(intBytes);
  32. int *A7;
  33. A7 = (int *)malloc(intBytes);
  34. float *B0;
  35. B0 = (float *)malloc(floatBytes);
  36. float *B1;
  37. B1 = (float *)malloc(floatBytes);
  38. float *B2;
  39. B2 = (float *)malloc(floatBytes);
  40. float *B3;
  41. B3 = (float *)malloc(floatBytes);
  42. float *B4;
  43. B4 = (float *)malloc(floatBytes);
  44. for(int i=0;i<924392;i++){
  45. A0[i] = 0*i+1;
  46. A1[i] = 48*i+1;
  47. A2[i] = 11+i+1;
  48. A3[i] = 83*i+1;
  49. A4[i] = 85*i+1;
  50. A5[i] = 56+i+1;
  51. A6[i] = 72+i+1;
  52. A7[i] = 79*i+1;
  53. B0[i] = 10.2153396964+i+1;
  54. B1[i] = 16.9417870332*i+1;
  55. B2[i] = 94.4633614094*i+1;
  56. B3[i] = 11.6539092131*i+1;
  57. B4[i] = 74.7461890372*i+1;
  58. }
  59. struct timeval time0,time1;
  60. gettimeofday(&time0,NULL);
  61. FILE *file_for_block_of_interest = fopen("./profile_in_block.txt","w");
  62. if(file_for_block_of_interest) {
  63. char Buf[2] = "1";
  64. fwrite(Buf, 1, 1, file_for_block_of_interest);
  65. fclose(file_for_block_of_interest);}
  66. kernel_cpu(A0,A1,A2,A3,A4,A5,A6,A7,B0,B1,B2,B3,B4,924392);
  67. file_for_block_of_interest = fopen("./profile_in_block.txt","w");
  68. if(file_for_block_of_interest) {
  69. char Buf[2] = "0";
  70. fwrite(Buf, 1, 1, file_for_block_of_interest);
  71. fclose(file_for_block_of_interest);}
  72. gettimeofday(&time1,NULL);
  73. double totaltime10 = (time1.tv_sec*1000000.0 + time1.tv_usec) - (time0.tv_sec*1000000.0 + time0.tv_usec);
  74. fprintf(stderr, "CPU time: %lf msecs ", (totaltime10)/1000.0F);
  75. free(A0);
  76. free(A1);
  77. free(A2);
  78. free(A3);
  79. free(A4);
  80. free(A5);
  81. free(A6);
  82. free(A7);
  83. free(B0);
  84. free(B1);
  85. free(B2);
  86. free(B3);
  87. free(B4);
  88. printf("\n");return 0; }