[Genabel-commits] r1853 - pkg/OmicABELnoMM/src

noreply at r-forge.r-project.org noreply at r-forge.r-project.org
Mon Oct 27 21:24:20 CET 2014


Author: lckarssen
Date: 2014-10-27 21:24:19 +0100 (Mon, 27 Oct 2014)
New Revision: 1853

Modified:
   pkg/OmicABELnoMM/src/Utility.cpp
   pkg/OmicABELnoMM/src/Utility.h
Log:
Cleaned up whitespace, long lines, etc. to bring OmicABELnoMM's Utility.{cpp,h} in compliance with the coding style guidlines.

No functional changes.


Modified: pkg/OmicABELnoMM/src/Utility.cpp
===================================================================
--- pkg/OmicABELnoMM/src/Utility.cpp	2014-10-27 17:07:22 UTC (rev 1852)
+++ pkg/OmicABELnoMM/src/Utility.cpp	2014-10-27 20:24:19 UTC (rev 1853)
@@ -1,27 +1,28 @@
 #include "Utility.h"
 
 
-double gemm_flops(double m, double n, double k,int sum)
+double gemm_flops(double m, double n, double k, int sum)
 {
-    return  (double)((2.0*m/1000.0*n/1000.0*k/1000.0+sum*m/1000.0*k/1000.0/1000.0));
+    return  (double)((2.0*m / 1000.0*n / 1000.0*k / 1000.0 +
+                      sum*m / 1000.0*k / 1000.0 / 1000.0));
 }
 
 
-
-void myassert(int cond,string msg,int var)
+void myassert(int cond, string msg, int var)
 {
-    if(!cond)
+    if (!cond)
     {
-        cout << msg << " "<<var << endl;
+        cout << msg << " "<< var << endl;
         exit(1);
     }
 }
 
-void myassert(int cond,string msg)
+
+void myassert(int cond, string msg)
 {
-    if(!cond)
+    if (!cond)
     {
-        cout << msg <<  endl;
+        cout << msg << endl;
         exit(1);
     }
 }
@@ -30,41 +31,46 @@
 type_precision* random_vec(int size)
 {
 
-    type_precision* vec = (type_precision*)malloc(size*sizeof(type_precision));
-    if(vec==0)
+    type_precision* vec =
+        (type_precision*)malloc(size * sizeof(type_precision));
+
+    if (vec == 0)
     {
-       cout << "\nNot enough RAM! " << (int)(size*sizeof(type_precision)/1024/1024) << "MB\n";
+       cout << "\nNot enough RAM! "
+            << (int)(size*sizeof(type_precision)/1024/1024) << "MB\n";
         //system("pause");
         exit(1);
     }
-    for( int i = 0; i < size; i++)
+
+    for (int i = 0; i < size; i++)
     {
         vec[i] = (type_precision)rand() / (type_precision)RAND_MAX;
     }
     return vec;
 }
 
+
 void re_random_vec(type_precision* vec, int size)
 {
-
-
-    for( int i = 0; i < size; i++)
+    for (int i = 0; i < size; i++)
     {
         vec[i] = (type_precision)rand() / (type_precision)RAND_MAX;
     }
 }
 
+
 void re_random_vec_nan(type_precision* vec, int size)
 {
     //int i;
 
-//    for( i = 0; i < size; i++)
+//    for ( i = 0; i < size; i++)
 //    {
-//        if((type_precision)rand() / (type_precision)RAND_MAX > 0.5)
+//        if ((type_precision)rand() / (type_precision)RAND_MAX > 0.5)
 //            vec[i] = nanf("");
 //    }
 }
 
+
 //no allocation!
 //inline void inlinecopy_vec(type_precision*old, type_precision* new_vec, int size)
 //{
@@ -72,218 +78,222 @@
 //}
 
 
-
-type_precision* replicate_vec(type_precision*old, int size)
+type_precision* replicate_vec(type_precision* old, int size)
 {
+    type_precision* vec =
+        (type_precision*)malloc(size * sizeof(type_precision));
 
-    type_precision* vec = (type_precision*)malloc(size*sizeof(type_precision));
-    if(vec==0)
+    if (vec==0)
     {
-        cout << "\nNot enough RAM! " << (int)(size*sizeof(type_precision)/1024/1024) << "MB\n";
+        cout << "\nNot enough RAM! "
+             << (int)(size*sizeof(type_precision)/1024/1024) << "MB\n";
         //system("pause");
         exit(1);
     }
 
-    memcpy( (type_precision*)vec, (type_precision*)old, size * sizeof(type_precision) );
+    memcpy( (type_precision*)vec,
+            (type_precision*)old,
+            size * sizeof(type_precision) );
 
     return vec;
 }
 
-void replace_nans_avgs(int vec_blocksize, type_precision* vec, int rows , int cols,list<long int>* ar_nan_idxs)
+
+void replace_nans_avgs(int vec_blocksize, type_precision* vec,
+                       int rows , int cols, list<long int>* ar_nan_idxs)
 {
     type_precision* ones = new type_precision[rows];
 
-
-    for( int i = 0; i < rows; i++)
+    for (int i = 0; i < rows; i++)
+    {
         ones[i] = 1.0;
+    }
 
-
-    for( int i = 0; i < vec_blocksize*cols; i++)
+    for (int i = 0; i < vec_blocksize * cols; i++)
     {
-        type_precision sum = cblas_sdot(rows, ones, 1, &vec[i*rows], 1);
-        type_precision avg = sum/(rows-ar_nan_idxs[i].size());
-        for (list<long int>::iterator it = ar_nan_idxs[i].begin(); it != ar_nan_idxs[i].end(); it++)
+        type_precision sum = cblas_sdot(rows, ones, 1, &vec[i * rows], 1);
+        type_precision avg = sum / (rows - ar_nan_idxs[i].size());
+        for (list<long int>::iterator it = ar_nan_idxs[i].begin();
+             it != ar_nan_idxs[i].end();
+             it++)
         {
-            int idx = i*rows+(*it);
+            int idx = i * rows + (*it);
             vec[idx] = avg;
         }
     }
 
     delete []ones;
-
 }
 
-void replace_nans(list<long int>* indexs_vec, int vec_blocksize, type_precision* vec, int rows , int cols)
+
+void replace_nans(list<long int>* indexs_vec, int vec_blocksize,
+                  type_precision* vec, int rows , int cols)
 {
-
     //#pragma omp parallel default(shared)
-    if(indexs_vec)
+    if (indexs_vec)
     {
-        for( int k = 0; k < vec_blocksize; k++)
+        for (int k = 0; k < vec_blocksize; k++)
         {
             indexs_vec[k].clear();
         }
     }
 
-    for( int k = 0; k < vec_blocksize; k++)
+    for (int k = 0; k < vec_blocksize; k++)
     {
         //#pragma omp for nowait  schedule(static)
-        for( int i = 0; i < cols; i++)//go thru all columns
+        for (int i = 0; i < cols; i++)      // go through all columns
         {
-
-             for( int j = 0; j < rows; j++)//move over the rows of this column
+             for (int j = 0; j < rows; j++) // move over the rows of this column
              {
+                int idx = k * cols * rows + i * rows + j;
 
-                int idx = k*cols*rows+i*rows+j;
-
                 //cout << idx;
-                if(idx >= rows*cols*vec_blocksize)
+                if (idx >= rows * cols * vec_blocksize)
+                {
                     exit(1);
+                }
 
-
-                if(isnan( vec[idx] ))
+                if (isnan(vec[idx] ))
                 {
                     vec[idx] = 0;
-                    if(indexs_vec)
+                    if (indexs_vec)
                     {
                         //this col had this rows with nans
                         indexs_vec[k].push_back(j);
                     }
-
                 }
-
              }
-
-
-
         }
-        if(indexs_vec)
+        if (indexs_vec)
         {
             indexs_vec[k].sort();
             indexs_vec[k].unique();
         }
-
-
-
     }
 
-
-    if(cols > 1)
+    if (cols > 1)
     {
-        replace_with_zeros(indexs_vec,vec,rows,cols,vec_blocksize);
+        replace_with_zeros(indexs_vec, vec, rows, cols, vec_blocksize);
     }
-
 }
 
-void replace_with_zeros(list<long int>* indexs, type_precision* vec, int n, int cols,int vec_block_count)
+
+void replace_with_zeros(list<long int>* indexs, type_precision* vec,
+                        int n, int cols, int vec_block_count)
 {
-    if(indexs)
+    if (indexs)
     {
-
-        for( int i = 0; i < vec_block_count; i++)
+        for (int i = 0; i < vec_block_count; i++)
         {
             int idx;
-            for( int j = 0; j < cols; j++)
+            for (int j = 0; j < cols; j++)
             {
-                for (list<long int>::iterator it = indexs->begin(); it != indexs->end(); it++)
+                for (list<long int>::iterator it = indexs->begin();
+                     it != indexs->end();
+                     it++)
                 {
-                    idx = i*cols*n+j*n+(*it);
+                    idx = i * cols * n + j * n + (*it);
                     vec[idx] = 0;
                 }
             }
         }
-
     }
 }
 
-void matlab_print_matrix(string name,int m,int n,type_precision* A)
+
+void matlab_print_matrix(string name, int m, int n, type_precision* A)
 {//fix for row major
-    if(PRINT)
+    if (PRINT)
     {
         cout << endl << name << " = [\n";
         int i;
         int j;
         int index=0;
-        for(j=0;j<m;j++)
+        for (j=0;j<m;j++)
         {
-          for(i=0;i<n;i++)
+          for (i=0;i<n;i++)
           {
-              if(i != 0)
-                printf(",\t");
-                index = j+i*m;
-            if(A[index] == 0.0)
-                {cout << " 0.000";}
-            else
-            {
-                 if(A[index] < 0.0)
-                    cout << std::setprecision(2) << A[index];
-                else
-                    cout << " "<<std::setprecision(2) << A[index];
-            }
+              if (i != 0)
+              {
+                  printf(", \t");
+              }
+              index = j + i * m;
+              if (A[index] == 0.0)
+              {
+                  cout << " 0.000";
+              }
+              else
+              {
+                  if (A[index] < 0.0)
+                  {
+                      cout << std::setprecision(2) << A[index];
+                  }
+                  else
+                  {
+                      cout << " "<<std::setprecision(2) << A[index];
+                  }
+              }
           }
           cout << " ; \n";
         }
         cout << "];\n";
-
     }
 }
 
 
-void cpu_benchmark(int n,int samples, double &duration, double &GFLOPS)
+void cpu_benchmark(int n, int samples, double &duration, double &GFLOPS)
 {
-    type_precision* A = new type_precision[n*n];
-    type_precision* B = new type_precision[n*n];
-    type_precision* C = new type_precision[n*n];
+    type_precision* A = new type_precision[n * n];
+    type_precision* B = new type_precision[n * n];
+    type_precision* C = new type_precision[n * n];
 
-
     cputime_type start_tick, end_tick;
     duration = 9999999999.0;
     int b = 0;
 
-    for(int i = 0; i < samples; i++)
+    for (int i = 0; i < samples; i++)
     {
+        re_random_vec(A, n*n);
+        re_random_vec(B, n*n);
+        re_random_vec(C, n*n);
 
-
-        re_random_vec(A,n*n);
-        re_random_vec(B,n*n);
-        re_random_vec(C,n*n);
-
         get_ticks(start_tick);
-        cblas_sgemm(CblasColMajor,CblasNoTrans,CblasNoTrans,n,n,n,1.0,A,n,B,n,1.0,C,n);
+        cblas_sgemm(CblasColMajor, CblasNoTrans, CblasNoTrans, n, n, n,
+                    1.0, A, n, B, n, 1.0, C, n);
         get_ticks(end_tick);
-        duration = min(duration,(double)(ticks2sec(end_tick,start_tick)));
+        duration = min(duration, (double)(ticks2sec(end_tick, start_tick)));
         int a = 0;
-        for(int j = 0; j < n*n ; j++)
+        for (int j = 0; j < n * n ; j++)
         {
-            a += A[j]+B[j]+C[j];
+            a += A[j] + B[j] + C[j];
         }
         b += a;
     }
     //!2nnn - nn + 2nn (from+c)
-    GFLOPS = gemm_flops(n,n,n,0);
+    GFLOPS = gemm_flops(n, n, n, 0);
 
-
     cout << b;
 
     delete []A;
     delete []B;
     delete []C;
-
 }
 
+
 float getTvalue(float pval)
 {
 //    cout << pval << endl;
-    float T = boost::math::erf_inv((long double)(1.0-pval))*sqrt(2.0);
+    float T = boost::math::erf_inv((long double)(1.0 - pval)) * sqrt(2.0);
 //    cout << T << endl;
     return T;
 }
 
+
 void float32(float* out, const uint16_t in)
 {
     uint32_t t1 = in;
-    t1 <<= 16;//convert to float again
-    t1 &= 0xffff0000;//keep sign and exponent only
+    t1 <<= 16;        // convert to float again
+    t1 &= 0xffff0000; // keep sign and exponent only
     *((uint32_t*)out) =  t1;
 }
 
@@ -292,7 +302,6 @@
 {
     uint32_t* intp = (uint32_t*)&(in);
     uint32_t inu = *(intp);
-    inu >>= 16; //left most 16 are kept after next truncation
-    out = inu;//truncates zeroes away
+    inu >>= 16; // left most 16 are kept after next truncation
+    out = inu;  // truncates zeroes away
 }
-

Modified: pkg/OmicABELnoMM/src/Utility.h
===================================================================
--- pkg/OmicABELnoMM/src/Utility.h	2014-10-27 17:07:22 UTC (rev 1852)
+++ pkg/OmicABELnoMM/src/Utility.h	2014-10-27 20:24:19 UTC (rev 1853)
@@ -8,29 +8,37 @@
 #include <vector>
 #include <list>
 #include <bitset>
-//
 
 
-double gemm_flops(double m, double n, double k,int sum);
-void myassert(int cond,string msg);
-void myassert(int cond,string msg,int var);
+double gemm_flops(double m, double n, double k, int sum);
+void myassert(int cond, string msg);
+void myassert(int cond, string msg, int var);
 type_precision* random_vec(int size);
 void re_random_vec(type_precision* vec, int size);
+
 inline void copy_vec(type_precision*old, type_precision* new_vec, int size)
 {
-    memcpy( (type_precision*)new_vec, (type_precision*)old, size * sizeof(type_precision) );
+    memcpy( (type_precision*)new_vec,
+            (type_precision*)old,
+            size * sizeof(type_precision) );
 }
+
 type_precision* replicate_vec(type_precision*old, int size);
-void matlab_print_matrix(string name,int m,int n,type_precision* A);
-void cpu_benchmark(int n,int samples, double &duration, double &gflops);
+void matlab_print_matrix(string name, int m, int n, type_precision* A);
+void cpu_benchmark(int n, int samples, double &duration, double &gflops);
 
 void re_random_vec_nan(type_precision* vec, int size);
 
-void replace_with_zeros(list<long int>* indexs, type_precision* vec, int n, int r,int block_count);
-void replace_nans(list<long int>* indexs, int blocksize, type_precision* vec, int rows , int cols);
-void replace_nans_avgs(int vec_blocksize, type_precision* vec, int rows , int cols,list<long int>* ar_nan_idxs);
+void replace_with_zeros(list<long int>* indexs, type_precision* vec,
+                        int n, int r, int block_count);
 
+void replace_nans(list<long int>* indexs, int blocksize,
+                  type_precision* vec, int rows , int cols);
 
+void replace_nans_avgs(int vec_blocksize, type_precision* vec,
+                       int rows , int cols, list<long int>* ar_nan_idxs);
+
+
 void float32(float* out, const uint16_t in);
 void float16(uint16_t &out, const float in);
 
@@ -38,14 +46,14 @@
 
 #define cputime_type struct timeval
 
-    #define get_ticks(t)\
-    {\
-          gettimeofday(&t, NULL);\
+#define get_ticks(t)                            \
+    {                                           \
+        gettimeofday(&t, NULL);                 \
     }
 
-    #define ticks2sec(end_time, start_time)\
-          ((int)(end_time.tv_sec  - start_time.tv_sec) * 1e6 +\
-                       (int)(end_time.tv_usec - start_time.tv_usec))/1000000.0\
+#define ticks2sec(end_time, start_time)                                 \
+    ((int)(end_time.tv_sec  - start_time.tv_sec) * 1e6 +                \
+     (int)(end_time.tv_usec - start_time.tv_usec))/1000000.0            \
 
 
 #endif // UTILITY_H_INCLUDED



More information about the Genabel-commits mailing list