Advertisement
lamiastella

Annotated_integralImage2D2D.c

Aug 4th, 2013
137
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C 2.48 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.       //int N=(nr*nc)-nc;
  29.       for(i=nr;i<N; i+=8)
  30.       {
  31.         togo = N - i;
  32.         size = (togo > 8) ? 8 : togo;
  33.         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)
  34.         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)
  35.         m5_rh_load_data(0, 1, 5 , 0); //two dependent addition
  36.  
  37.         for(j=0; j<size; j++)
  38.         {
  39.             asubsref(integralImg,i+j) = asubsref(integralImg, i-nc +j) + asubsref(SAD,i+j);
  40.         }
  41.         m5_rh_load_data(integramImg->data+i, size*4, 4, 1); //store results
  42.         m5_rh_load_data(0, 0, 0, 0);
  43.       }
  44.      m5rh_start(101,0);
  45.    
  46.  
  47.      
  48.      /*original code
  49.       for(i=0; i<nr; i++)
  50.         for(j=1; j<nc; j++)
  51.             subsref(integralImg,i,j) = subsref(integralImg, i, (j-1)) + subsref(integralImg,i,j);
  52.        */
  53.       m5rh_start(102,1);
  54.       for(i=0; i<N; i+=8)
  55.             {
  56.            
  57.               togo = N - i;
  58.               size = (togo > 8) ? 8 : togo;
  59.               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)
  60.               m5_rh_load_data(0, 1, 5 , 0); //two dependent addition
  61.               for(j=0; j<size; j++)
  62.               {
  63.                     if (((i+j) % nc) != 0)
  64.                        {
  65.                           asubsref(integralImg,i+j) = asubsref(integralImg, i+j-1) + asubsref(integralImg,i+j);
  66.  
  67.                        }
  68.               }
  69.               m5_rh_load_data(integramImg->data+i, size*4, 4, 1); //store results
  70.               m5_rh_load_data(0, 0, 0, 0);
  71.            
  72.             }
  73.      m5rh_start(102,0);
  74.  
  75.     return;
  76.    
  77. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement