ctest662.c 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  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,float *B0,float *B1,float *B2,float *B3,float *B4,float *B5,float *B6,float *B7,float *B8,int N){
  5. for(int i=0;i<N;i++){
  6. A0[i] = A3[i]+A3[i];
  7. A1[i] = A3[i]/A3[i]*A3[i];
  8. A2[i] = A3[i]-A3[i]+A3[i];
  9. B0[i] = B7[i];
  10. B1[i] = B5[i]*B8[i];
  11. B2[i] = B5[i]-B6[i];
  12. B3[i] = B7[i];
  13. B4[i] = B6[i]-B5[i];
  14. }
  15. }
  16. int main(int argc,char **argv) {
  17. int size=795697;
  18. int intBytes = size*sizeof(int);
  19. int floatBytes = size*sizeof(float);
  20. int *A0;
  21. A0 = (int *)malloc(intBytes);
  22. int *A1;
  23. A1 = (int *)malloc(intBytes);
  24. int *A2;
  25. A2 = (int *)malloc(intBytes);
  26. int *A3;
  27. A3 = (int *)malloc(intBytes);
  28. float *B0;
  29. B0 = (float *)malloc(floatBytes);
  30. float *B1;
  31. B1 = (float *)malloc(floatBytes);
  32. float *B2;
  33. B2 = (float *)malloc(floatBytes);
  34. float *B3;
  35. B3 = (float *)malloc(floatBytes);
  36. float *B4;
  37. B4 = (float *)malloc(floatBytes);
  38. float *B5;
  39. B5 = (float *)malloc(floatBytes);
  40. float *B6;
  41. B6 = (float *)malloc(floatBytes);
  42. float *B7;
  43. B7 = (float *)malloc(floatBytes);
  44. float *B8;
  45. B8 = (float *)malloc(floatBytes);
  46. for(int i=0;i<795697;i++){
  47. A0[i] = 98*i+1;
  48. A1[i] = 21*i+1;
  49. A2[i] = 21*i+1;
  50. A3[i] = 42+i+1;
  51. B0[i] = 80.0484588733*i+1;
  52. B1[i] = 66.8978958818+i+1;
  53. B2[i] = 72.5482902601+i+1;
  54. B3[i] = 11.9803865406+i+1;
  55. B4[i] = 47.3136207613*i+1;
  56. B5[i] = 11.6842424037+i+1;
  57. B6[i] = 7.46022196291*i+1;
  58. B7[i] = 44.9554189278*i+1;
  59. B8[i] = 12.3976090838*i+1;
  60. }
  61. struct timeval time0,time1;
  62. gettimeofday(&time0,NULL);
  63. FILE *file_for_block_of_interest = fopen("./profile_in_block.txt","w");
  64. if(file_for_block_of_interest) {
  65. char Buf[2] = "1";
  66. fwrite(Buf, 1, 1, file_for_block_of_interest);
  67. fclose(file_for_block_of_interest);}
  68. kernel_cpu(A0,A1,A2,A3,B0,B1,B2,B3,B4,B5,B6,B7,B8,795697);
  69. file_for_block_of_interest = fopen("./profile_in_block.txt","w");
  70. if(file_for_block_of_interest) {
  71. char Buf[2] = "0";
  72. fwrite(Buf, 1, 1, file_for_block_of_interest);
  73. fclose(file_for_block_of_interest);}
  74. gettimeofday(&time1,NULL);
  75. double totaltime10 = (time1.tv_sec*1000000.0 + time1.tv_usec) - (time0.tv_sec*1000000.0 + time0.tv_usec);
  76. fprintf(stderr, "CPU time: %lf msecs ", (totaltime10)/1000.0F);
  77. free(A0);
  78. free(A1);
  79. free(A2);
  80. free(A3);
  81. free(B0);
  82. free(B1);
  83. free(B2);
  84. free(B3);
  85. free(B4);
  86. free(B5);
  87. free(B6);
  88. free(B7);
  89. free(B8);
  90. printf("\n");return 0; }