Advertisement
lamiastella

modified_oneKernel_integralImage2D2D.c

Aug 7th, 2013
125
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C 2.66 KB | None | 0 0
  1.     /********************************
  2.     Author: Sravanthi Kota Venkata
  3.     ********************************/
  4.      
  5.     #include <stdio.h>
  6.     #include <stdlib.h>
  7.     #include "disparity.h"
  8.     #include "m5op.h"
  9.     void integralImage2D2D(F2D* SAD, F2D* integralImg)
  10.     {
  11.         int nr, nc, i, j;
  12.        
  13.         nr = SAD->height;
  14.         nc = SAD->width;
  15.         int togo,size;
  16.         for(i=0; i<nc; i++)
  17.             subsref(integralImg,0,i) = subsref(SAD,0,i);
  18.          
  19.           /* original code
  20.           for(i=1; i<nr; i++)
  21.                 for(j=0; j<nc; j++)
  22.                 {
  23.                     subsref(integralImg,i,j) = subsref(integralImg, (i-1), j) + subsref(SAD,i,j);
  24.                 }
  25.            */
  26.           m5rh_start(101,1);    
  27.           int N=nr*nc;
  28.           for(i=nr;i<N; i+=8)
  29.           {
  30.             togo = N - i;
  31.             size = (togo > 8) ? 8 : togo;
  32.             m5_rh_load_data(integralImg->data+i, size*4, 4, 1); //load data as many data elements as the number of size (each int/float size is 4 byte)
  33.             m5_rh_load_data(SAD->data+i, size*4, 4, 1); //load data as many data elements as the number of size (each int/float size is 4 byte)
  34.             m5_rh_load_data(0, 1, 5 , 0); //one addition
  35.      
  36.             for(j=0; j<size; j++)
  37.             {
  38.                 asubsref(integralImg,i+j) = asubsref(integralImg, i-nc +j) + asubsref(SAD,i+j);
  39.             }
  40.             m5_rh_load_data(integramImg->data+i, size*4, 4, 1); //store results
  41.             m5_rh_load_data(0, 0, 0, 0);
  42.           }
  43.        
  44.          
  45.          /*original code
  46.           for(i=0; i<nr; i++)
  47.             for(j=1; j<nc; j++)
  48.                 subsref(integralImg,i,j) = subsref(integralImg, i, (j-1)) + subsref(integralImg,i,j);
  49.            */
  50.           for(i=0; i<N; i+=8)
  51.                 {
  52.                   togo = N - i;
  53.                   size = (togo > 8) ? 8 : togo;
  54.                   m5_rh_load_data(integralImg->data+i, size*4, 4, 1); //load data as many data elements as the number of size (each int/float size is 4 byte)
  55.                   m5_rh_load_data(0, 1, 5 , 0); //one dependent addition
  56.                   for(j=0; j<size; j++)
  57.                   {
  58.                         if (((i+j) % nc) != 0)
  59.                            {
  60.                               asubsref(integralImg,i+j) = asubsref(integralImg, i+j-1) + asubsref(integralImg,i+j);
  61.      
  62.                            }
  63.                   }
  64.                   m5_rh_load_data(integramImg->data+i, size*4, 4, 1); //store results
  65.                   m5_rh_load_data(0, 0, 0, 0);
  66.                
  67.                 }
  68.          m5rh_start(101,0);
  69.      
  70.         return;
  71.        
  72.     }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement