Exemplo n.º 1
0
void adpt_wt_mn9( int num , double to,double dt, float *vec )
{
   float x[9] , *nv ; int ii,jj,kk , n1=num-1 ;

   nv = (float *)malloc(sizeof(float)*num) ;

   for( ii=0 ; ii < num ; ii++ ){

     for( jj=-4 ; jj <= 4 ; jj++ ){
       kk = ii+jj ; if( kk < 0 ) kk = 0 ; else if( kk > n1 ) kk = n1 ;
       x[jj+4] = vec[kk] ;
     }

     nv[ii] = adaptive_weighted_mean( 9 , x ) ;
   }

   memcpy(vec,nv,sizeof(float)*num) ; free(nv) ; return ;
}
Exemplo n.º 2
0
void adapt_mean_21_box_func( int nx, int ny, double dx, double dy, float *ar )
{
   int ii , jj , nxy , joff ;
   float aa[21] ;
   float *ajj , *ajm , *ajp , *ajmm , *ajpp ;

   if( nx < 5 || ny < 5 ) return ;

   /** make space and copy input into it **/

   nxy = nx * ny ;
   MAKE_ATEMP(nxy) ; if( atemp == NULL ) return ;
   memcpy(atemp,ar,sizeof(float)*nxy) ;

   /** process copy of input back into the input array **/

   for( jj=1 ; jj < ny-1 ; jj++ ){

      joff = jj * nx ;      /* offset into this row */
      ajj  = atemp + joff ; /* pointer to this row */

      ajm  = ajj-nx ;  /* pointer to last row */
      ajp  = ajj+nx ;  /* pointer to next row */

      ajmm = (jj == 1  ) ? ajm : ajm-nx ;  /* to last last row */
      ajpp = (jj ==ny-2) ? ajp : ajp+nx ;  /* to next next row */

      /* do interior points of this row */

      for( ii=2 ; ii < nx-2 ; ii++ ){
         aa[0]=ajmm[ii-1]; aa[1]=ajmm[ii]; aa[2]=ajmm[ii+1];

         aa[ 3]=ajm[ii-2]; aa[ 4]=ajm[ii-1]; aa[ 5]=ajm[ii]; aa[ 6]=ajm[ii+1]; aa[ 7]=ajm[ii+2];
         aa[ 8]=ajj[ii-2]; aa[ 9]=ajj[ii-1]; aa[10]=ajj[ii]; aa[11]=ajj[ii+1]; aa[12]=ajj[ii+2];
         aa[13]=ajp[ii-2]; aa[14]=ajp[ii-1]; aa[15]=ajp[ii]; aa[16]=ajp[ii+1]; aa[17]=ajp[ii+2];

         aa[18]=ajpp[ii-1]; aa[19]=ajpp[ii]; aa[20]=ajpp[ii+1];

         ar[ii+joff] = adaptive_weighted_mean( 21 , aa ) ;
      }
   }
   return ;
}
Exemplo n.º 3
0
Arquivo: 3dTfilter.c Projeto: nno/afni
void adaptive_filter( int num , float *vec )
{
   int ii,jj,kk , n1=num-1 ;

   if( num < 2 || vec == NULL || nHH <= 0 ) return ;

   if( aXX == NULL ){ aXX = (float *)malloc(sizeof(float)*nXX) ; }
   if( ntv < num ){ tvv = (float *)realloc(tvv,sizeof(float)*num) ; ntv = num ; }

   for( ii=0 ; ii < num ; ii++ ){
     for( jj=-nHH ; jj <= nHH ; jj++ ){
       kk = ii+jj ; if( kk < 0 ) kk = 0 ; else if( kk > n1 ) kk = n1 ;
       aXX[jj+nHH] = vec[kk] ;
     }
     tvv[ii] = adaptive_weighted_mean( nXX , aXX ) ;
   }

   memcpy(vec,tvv,sizeof(float)*num) ; return ;
}