Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum. Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !

EXEMPLE D'UTILISATION DE LA TRANSFORMEE DE FOURIER DISCRETE


Information sur la source

Description

Ceci est un programme permettant de calculer la Transformee de Fourier Discrète de la fonction f(x) = x(1-x) sur l'intervalle [0,1].
Je débute en Java donc il se peut que mon code ne soit pas trop optimisé,
n'hésiter à mettre des commentaires.
 

Source

  • import java.io.*;
  • import java.lang.*;
  • class DFT
  • { static int NMAX = 128;
  • static int MMAX = 8;
  • static double [] fr = new double[NMAX];
  • static double [] fi = new double[NMAX];
  • static double [] gr = new double[NMAX];
  • static double [] gi = new double[NMAX];
  • static void dft(double [] fr, double [] fi,double [] gr,double [] gi, int n)
  • {
  • int i,j;
  • double pi,x,q;
  • pi = 4*Math.atan(1);
  • x = 2*pi/n;
  • for (i = 0; i < n; ++i)
  • {
  • gr[i] = 0;
  • gi[i] = 0;
  • for (j = 0; j < n; ++j)
  • {
  • q = x*j*i;
  • gr[i] = gr[i]+fr[j]*Math.cos(q)+fi[j]*Math.sin(q);
  • gi[i] = gi[i]+fi[j]*Math.cos(q)-fr[j]*Math.sin(q);
  • }
  • }
  • }
  • public static void main( String argv[] ) {
  • int i,n,m;
  • double f0,h,rn,x;
  • //double fr[],fi[],gr[],gi[];
  • double [] fr = new double[NMAX];
  • double [] fi = new double[NMAX];
  • double [] gr = new double[NMAX];
  • double [] gi = new double[NMAX];
  • n = NMAX;
  • m = MMAX;
  • h = 1.0/(n-1);
  • rn = n;
  • f0 = 1/Math.sqrt(rn);
  • for (i = 0; i < n; ++i)
  • {
  • x = h*i;
  • fr[i] = x*(1-x);
  • fi[i] = 0;
  • }
  • dft (fr,fi,gr,gi,n);
  • for (i = 0; i < n; ++i)
  • {
  • gr[i] = f0*gr[i];
  • gi[i] = f0*gi[i];
  • }
  • /* execution de la transformee inverse */
  • for (i = 0; i < n; ++i)
  • {
  • gi[i] = -gi[i];
  • }
  • dft (gr,gi,fr,fi,n);
  • for (i = 0; i < n; ++i)
  • {
  • fr[i] = f0*fr[i];
  • fi[i] = -f0*fi[i];
  • if (i == 0 || i%m == 0)
  • {
  • x = h*i;
  • System.out.println(x + " " + fr[i] );
  • }
  • }
  • }
  • }
import java.io.*;
import java.lang.*;

class DFT 
{   static  int NMAX = 128; 
    static  int MMAX = 8;

static double [] fr = new double[NMAX]; 
static double [] fi = new double[NMAX];
static double [] gr = new double[NMAX];
static double [] gi = new double[NMAX];

static void dft(double [] fr, double [] fi,double [] gr,double [] gi, int n) 
{


int i,j;
double pi,x,q;

pi = 4*Math.atan(1);
x  = 2*pi/n;

for (i = 0; i < n; ++i)
  {
  gr[i] = 0;
  gi[i] = 0;
  for (j = 0; j < n; ++j)
    {
    q = x*j*i;
    gr[i] = gr[i]+fr[j]*Math.cos(q)+fi[j]*Math.sin(q);
    gi[i] = gi[i]+fi[j]*Math.cos(q)-fr[j]*Math.sin(q);
    }
  }
}


public static void main( String argv[] ) { 

int i,n,m;
double f0,h,rn,x;
//double fr[],fi[],gr[],gi[];
double [] fr = new double[NMAX];
double [] fi = new double[NMAX];
double [] gr = new double[NMAX];
double [] gi = new double[NMAX];
n = NMAX;
m = MMAX;
h = 1.0/(n-1);
rn = n;
f0 = 1/Math.sqrt(rn);

for (i = 0; i < n; ++i)
  {
  x = h*i;
  fr[i] = x*(1-x);
  fi[i] = 0;
  }
dft (fr,fi,gr,gi,n);
for (i = 0; i < n; ++i)
  {
  gr[i] = f0*gr[i];
  gi[i] = f0*gi[i];
  }

/* execution de la transformee inverse */

for (i = 0; i < n; ++i)
  {
  gi[i] = -gi[i];
  }
dft (gr,gi,fr,fi,n);
for (i = 0; i < n; ++i)
  {
  fr[i] =  f0*fr[i];
  fi[i] = -f0*fi[i];
  if (i == 0 || i%m == 0)
    {
    x = h*i;
    System.out.println(x + " " + fr[i] );
    }
  }
}
}

Commentaires et avis

Aucun commentaire pour le moment.

Ajouter un commentaire



Nos sponsors

Sondage...

CalendriCode

Décembre 2008
LMMJVSD
1234567
891011121314
15161718192021
22232425262728
293031    

Consulter la suite du CalendriCode



Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel BAÏSE, Merci à Vincent pour ses précieux conseils
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés
Temps d'éxécution de la page : 0,218 sec

Google Coop CodeS-SourceS Google Coop CodeS-SourceS


Certaines images présentes sur le site (notament certains avatars) sont issues des collections IconShock, donc si vous souhaitez utiliser ces icons vous devez les acheter, ne les copiez pas et ne utilisez pas dans vos sites et applications sans les avoir commandé.