회원가입 ID/PW 찾기

1) 지식 창고는 본인이 작성한 콘텐츠(팁/노하우/리소스/강좌 등)을 무료 혹은 가상화폐인 납포인트를 통해 공유하는 공간입니다.
2) 본인이 작성한 콘텐츠에 대해서만 지식 창고에 등록할 수 있으며, 저작권에 위배되는 콘텐츠는 사전경고 없이 삭제될 수 있습니다.
3) 콘텐츠 구매 및 첨부파일 다운로드는 회원그룹 '연구원' 이상 가능하오니, 경험치를 쌓아 진급한 후에 이용 부탁드립니다.
4) 무료 콘텐츠의 본문은 구매절차 없이 즉시 이용할 수 있으며, 판매 납포인트가 있는 콘텐츠는 구매 후 이용할 수 있습니다.
5) 콘텐츠 판매에 따른 납포인트 수익은 지정한 비율(50%)에 따라 판매자에게 지급하며, 납포인트 수익을 통해 진급을 빨리할 수 있습니다.
6) 구매 후 평가를 하면 구매 납포인트의 20%를 돌려 드립니다.

콘텐츠 수 69

푸리에변환

마이크로프로세서 구매수 0 2010.02.09 14:40:34
판매자 lion 판매 납포인트 무료 평점 0점 / 총 0명 참여

#include<stdio.h>
#include<math.h>
#define nFFT 16
#define nFFT3_4 ((nFFT*3)/4)

double wn_FFT[nFFT3_4];  /* for twiddle factor */
short br_FFT[nFFT];     /* for bit reversal   */
double xr[nFFT], xi[nFFT], yr[nFFT], yi[nFFT];


void fft_table(double wn_FFT[], short br_FFT[], int N_FFT);
void fft(double xr[], double xi[], double wn_FFT[], short br_FFT[], int N_FFT);
void swap(double *a, double *b);

/***************************/
/* Genarate tables for FFT */
/***************************/
void fft_table(double wn_FFT[], short br_FFT[], int N_FFT)
{
    int i, n_half, ne, jp;
    double arg;
/* Calculation of twiddle factor */
    arg = 6.283185307f/N_FFT;
    for (i=0; i<((N_FFT*3)>>2); i++) wn_FFT[i] = cos(arg*i);
/* Calculation of bit reversal table */
    n_half = N_FFT>>1;
    br_FFT[0] = 0;
    for (ne=1; ne<N_FFT; ne=ne<<1)
    {
        for (jp=0; jp<ne; jp++) br_FFT[jp+ne] = br_FFT[jp] + n_half;
        n_half = n_half>>1;
    }
}

/**************************/
/* FFT for complex signal */
/**************************/
void fft(double xR[], double xI[], double wn_FFT[], short br_FFT[], int N_FFT)
{
    double xtmpR, xtmpI;
    int   j, jnh, k, jxC, jxS, ne, n_half, n_half2;

    n_half = N_FFT>>1;
    for (ne=1; ne<N_FFT; ne=ne<<1)
    {
        n_half2 = n_half<<1;
        for (k=0; k<N_FFT; k=k+n_half2)
        {
            jxC = 0;
            jxS = N_FFT>>2;
            for (j=k; j<(k+n_half); j++)
            {
                jnh = j + n_half;
/* beginning of butterfly operations */
                xtmpR = xR[j];
                xtmpI = xI[j];
                xR[j] = xtmpR + xR[jnh];
                xI[j] = xtmpI + xI[jnh];
                xtmpR = xtmpR - xR[jnh];
                xtmpI = xtmpI - xI[jnh];
                xR[jnh] = xtmpR*wn_FFT[jxC] - xtmpI*wn_FFT[jxS];
                xI[jnh] = xtmpR*wn_FFT[jxS] + xtmpI*wn_FFT[jxC];
/* end of butterfly operations */
                jxC = jxC + ne;
                jxS = jxS + ne;
            }
        }
        n_half = n_half>>1;
    }
/* Bit reverse */
    for (j=0; j<N_FFT; j++)
        if (j<br_FFT[j])
        {
             swap(&xR[j], &xR[br_FFT[j]]);
             swap(&xI[j], &xI[br_FFT[j]]);
        }
}

/* used in FFT procedure */
void swap(double *a, double *b)
{
    double tmp;
    tmp = *a;
    *a = *b;
    *b = tmp;
}

void main()
{
 short i;


    fft_table(wn_FFT, br_FFT, nFFT);       /* ganarate tables for FFT */
/* genarate rectangular wave */

    for (i=0; i<nFFT; i++)
    {                                   
            xr[i] =sin(6.28*i/3);
    }

    for (i=0; i<nFFT; i++)
    {
        yr[i] = xr[i];
        yi[i] = xi[i];
    }

    fft(yr, yi, wn_FFT, br_FFT, nFFT);     /* FFT */

 for(i=0;i<nFFT;i++)
 {
  printf("%f ",xr[i]);
 }
 printf("\n\n ");
 for(i=0;i<nFFT;i++)
 {
  printf("%f ",yi[i]);
 }
}

 


 

search
List of Articles
번호 분류 제목 평점 포인트 판매자 등록일 구매수 조회 수
공지 공공의 목적으로 공유하고자 하는 소프트웨어는 '소프트웨어 자료실'에 업로드를 요청드립니다.
공지 구매후 평점 댓글을 남겨주시면 구매포인트의 20%를 돌려드립니다.
69 머신러닝, AI & 알고리즘 matlab 쉽게 배우는 방법없나요? [7] 무료 kayle 2013-09-26 0 441
68 머신러닝, AI & 알고리즘 Kalman 필터로 쉽게 센서통합하기 [8] 무료 아크마 2011-08-01 0 2995
67 머신러닝, AI & 알고리즘 매크로 이름에 괄호를 사용하기 [5] 무료 밝은전기구슬 2011-03-28 0 4925
66 머신러닝, AI & 알고리즘 Solving ODEs with MATLAB [3] 무료 HALU13 2010-11-29 0 2156
65 머신러닝, AI & 알고리즘 A Guide to MATLAB Object-Oriented Programming - Andy H. Register [5] 무료 HALU13 2010-11-29 0 2299
64 머신러닝, AI & 알고리즘 매트랩 한글 메뉴얼 입니다. [33] 무료 우당탕카 2010-06-01 0 5727
63 머신러닝, AI & 알고리즘 보간법 매틀랩 코드입니다. 무료 나얼제자 2010-05-25 0 4140
62 머신러닝, AI & 알고리즘 매틀랩 명령어 정리 입니다 [14] 무료 지노쟁이 2010-04-29 0 4648
61 머신러닝, AI & 알고리즘 matlab이 저에게 필요한가요 [5] 무료 딘재 2010-04-16 0 2250
60 머신러닝, AI & 알고리즘 공업수학요약정리4 [10] 무료 알라뷰 2010-03-07 0 2525
59 머신러닝, AI & 알고리즘 공업수학요약정리3 [8] 무료 알라뷰 2010-03-07 0 2483
58 머신러닝, AI & 알고리즘 공업수학요약정리2 [8] 무료 알라뷰 2010-03-07 0 2061
57 머신러닝, AI & 알고리즘 공업수학요약정리1 [12] 무료 알라뷰 2010-03-07 0 3187
56 머신러닝, AI & 알고리즘 proxmity sensing 알고리즘입니다. [2] 무료 퀴아쿠 2010-02-19 0 2047
55 머신러닝, AI & 알고리즘 알고리즘 설계 및 실습 - Huffman & Dijkstra [5] 무료 블루미르7 2010-01-05 0 3471
54 머신러닝, AI & 알고리즘 간단한 비례 공식입니다 ㅎㅎ [2] 무료 karismapong 2009-10-20 0 2648
53 머신러닝, AI & 알고리즘 Euler 미분법[MATLAB] [4] 무료 아크마 2009-10-01 0 4642
52 머신러닝, AI & 알고리즘 Matlab코드를 C코드로 변환할 수 있다는데.. 무료 kezman 2009-09-25 0 4195
51 머신러닝, AI & 알고리즘 MPLAB 컴파일을 했더니 에러가 떠요..ㅠㅠ [2] 무료 로이lee 2009-04-16 0 3969
50 머신러닝, AI & 알고리즘 (MATLAB) S-ALOHA의 Throughput 시뮬레이션 소스 [2] 무료 태상노군 2008-09-23 0 5173
  • 애정의 수단으로 행복해지는 유일한 길이 있다. 즉 아무도 사랑하지 않는 것이다.
    - P.부 르제
  • * 납포인트 정보 *
  • 글 작성 : 3
  • 댓글 작성 : 1
저작권법에 위배되는 콘텐츠는 등록 불가하며, 저작물에 대한 권리는 저작자에게 있습니다.
Copyright 2006-2021 © hardwareis.com, All rights reserved.