⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 fft2drad.c

📁 image processing including fourier,wavelet,segmentation etc.
💻 C
字号:
/*--------------------------- MegaWave2 Command -----------------------------*//* mwcommand   name = {fft2drad};   version = {"1.1"};   author = {"Lionel Moisan"};   function = {"compute average spectrum as a radial function"};   usage = {'l'->l_flag          "take log10",'s':size->size       "output size (number of cells), default min(nx,ny)",'I':input_im->in_im  "imaginary input (Fimage)",input_re->in_re      "real input (Fimage)",out<-out             "output |FFT|=f(r) (Fsignal)"   };*/#include <stdio.h>#include <math.h>#include "mw.h"extern void fft2dpol();/* NB : as for fft2d :      * calling this module with in_im=NULL is possible and means        in_im(x,y) = 0 everywhere */Fsignal fft2drad(in_re,in_im,out,l_flag,size)     Fimage in_re, in_im;     Fsignal out;     char *l_flag;     int *size;{  Fimage rho;  int n,x,y,xx,yy,r,nx,ny,*count;  double cx,cy;  rho = mw_new_fimage();  fft2dpol(in_re,in_im,rho,NULL,NULL);  nx = rho->ncol;  ny = rho->nrow;  if (size) n=*size;   else n=(int)ceil((double)(nx<ny?nx:ny)*sqrt(0.5));  out = mw_change_fsignal(out,n+1);  /* l'閏helle est en lignes par pixel */  out->scale = (float)sqrt(0.5)/(float)n;  mw_clear_fsignal(out,0.);  count = (int *)calloc(n+1,sizeof(int));  cx = 1./(double)(nx*nx);  cy = 1./(double)(ny*ny);  for (x=nx;x--;)    for (y=ny;y--;) {      xx = (x>nx/2?nx-x:x);      yy = (y>ny/2?ny-y:y);      r = (int)(0.5+ sqrt(cx*(double)(xx*xx)+cy*(double)(yy*yy))		/(double)out->scale );      if (r>n-1) r=n-1;      out->values[r] += rho->gray[y*nx+x];      count[r]++;    }  for (r=n;r--;) if (count[r]) out->values[r] /= (float)count[r];  if (l_flag) for (r=n;r--;) if (out->values[r])    out->values[r] = (float)log10((double)out->values[r]);  free(count);  mw_delete_fimage(rho);  return(out);}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -