IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

OpenCV Discussion :

Une DFT inverse après une DFT ne donne pas l'image d'origine


Sujet :

OpenCV

  1. #1
    Membre averti
    Inscrit en
    Mai 2006
    Messages
    35
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 35
    Par défaut Une DFT inverse après une DFT ne donne pas l'image d'origine
    Bonjour,
    Avec la fonction cvDft j applique une transformée de fourrier sur une image 8 bit en niveau de gris et lorsque j'applique la cvDft inverse je n'obtiens pas l'image d'origine sachant que je n'ai retiré aucun coefficient après la transformée directe.
    Quelqu'un a une explication ?
    Merci

  2. #2
    Membre averti
    Inscrit en
    Mai 2006
    Messages
    35
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 35
    Par défaut une DFT inverse après une DFT ne donnant pas l'image d'origine (code)
    Voici le bout de code que j'utilise :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    IplImage *dst= cvCreateImage(cvGetSize(src),IPL_DEPTH_8U, 1);
    	IplImage* realInput = cvCreateImage( cvGetSize(src), IPL_DEPTH_64F, 1);
    	IplImage* imaginaryInput = cvCreateImage( cvGetSize(src), IPL_DEPTH_64F, 1);
    	IplImage* complexInput = cvCreateImage( cvGetSize(src), IPL_DEPTH_64F, 2);		
    	int dft_M = cvGetOptimalDFTSize( src->height - 1 );
    	int dft_N = cvGetOptimalDFTSize( src->width - 1 );
    	CvMat* dft_A = cvCreateMat( dft_M, dft_N, CV_64FC2 );
     
     
    	IplImage* image_Re = cvCreateImage( cvSize(dft_N, dft_M), IPL_DEPTH_64F, 1);
    	IplImage* image_Im = cvCreateImage( cvSize(dft_N, dft_M), IPL_DEPTH_64F, 1);
     
     
    	cvScale(src, realInput, 1.0, 0.0);
    	cvZero(imaginaryInput);
    	cvMerge(realInput, imaginaryInput, NULL, NULL, complexInput);
     
    	// copy A to dft_A 
     
    	cvGetSubRect( dft_A, &tmp, cvRect(0,0, src->width,src->height));
    	cvCopy( complexInput, &tmp, NULL );
    	cvGetSubRect( dft_A, &tmp, cvRect(src->width,0, src->cols - src->width, src->height));
     
    	if ((dft_A->cols - src->width) > 0)			  
    	{
    		cvZero( &tmp );
    	}	
    	// Fourier transform
    	cvDFT( dft_A, dft_A, CV_DXT_FORWARD, complexInput->height );
     
    	// Inverse Fourier transform
    	cvDFT( dft_A, dft_A, CV_DXT_INVERSE , complexInput->height );
     
    	cvGetSubRect( dft_A, &tmp, cvRect(0,0, src->width,src->height));
     
    	// Split Fourier in real and imaginary parts
    	cvSplit( dft_A, image_Re, image_Im, 0, 0 );
     
    	// scale image for display
    	cvMinMaxLoc(image_Re, &m, &M, NULL, NULL, NULL);
    	cvScale(image_Re, image_Re, 1.0/(M-m), 1.0*(-m)/(M-m));
     
    	image_Re->origin = src->origin;
     
     
    	for(i=0;i<dst->height;i++)
    	{
    		for(j=0;j<dst->width;j++)
    		{
    			dst->imageData[j+(i*dst->width)]=(unsigned char)((255)*(((double*)image_Re->imageData)[(j+(image_Re->width-dst->width)/2)+((i+(image_Re->height-dst->height)/2)*(image_Re->width))]));//(unsigned char)(min(255*(((double*)image_Re->imageData)[(j+(image_Re->width-dst->width)/2)+((i+(image_Re->height-dst->height)/2)*(image_Re->width))]),255));
    		}
    	}
     
    	cvSaveImage("src.bmp",src);
    	cvSaveImage("dst.bmp",dst);
    	// Compute differences image
    	cvSub(src,dst,dst,0);
    	cvSaveImage("difference.bmp",dst);

  3. #3
    Membre averti
    Inscrit en
    Mai 2006
    Messages
    35
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 35
    Par défaut Code corrigé
    voici le code corrigé :
    Une ligne s'était glissée dedans et avait généré cette erreur et donc maintenant ça marche :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    IplImage *dst= cvCreateImage(cvGetSize(src),IPL_DEPTH_8U, 1);
    	IplImage* realInput = cvCreateImage( cvGetSize(src), IPL_DEPTH_64F, 1);
    	IplImage* imaginaryInput = cvCreateImage( cvGetSize(src), IPL_DEPTH_64F, 1);
    	IplImage* complexInput = cvCreateImage( cvGetSize(src), IPL_DEPTH_64F, 2);		
    	int dft_M = cvGetOptimalDFTSize( src->height - 1 );
    	int dft_N = cvGetOptimalDFTSize( src->width - 1 );
    	CvMat* dft_A = cvCreateMat( dft_M, dft_N, CV_64FC2 );
     
     
    	IplImage* image_Re = cvCreateImage( cvSize(dft_N, dft_M), IPL_DEPTH_64F, 1);
    	IplImage* image_Im = cvCreateImage( cvSize(dft_N, dft_M), IPL_DEPTH_64F, 1);
     
     
    	cvScale(src, realInput, 1.0, 0.0);
    	cvZero(imaginaryInput);
    	cvMerge(realInput, imaginaryInput, NULL, NULL, complexInput);
     
    	// copy A to dft_A 
     
    	cvGetSubRect( dft_A, &tmp, cvRect(0,0, src->width,src->height));
    	cvCopy( complexInput, &tmp, NULL );
    	cvGetSubRect( dft_A, &tmp, cvRect(src->width,0, src->cols - src->width, src->height));
     
    	if ((dft_A->cols - src->width) > 0)			  
    	{
    		cvZero( &tmp );
    	}	
    	// Fourier transform
    	cvDFT( dft_A, dft_A, CV_DXT_FORWARD, complexInput->height );
     
    	// Inverse Fourier transform
    	cvDFT( dft_A, dft_A, CV_DXT_INVERSE , complexInput->height );
     
    	// Split Fourier in real and imaginary parts
    	cvSplit( dft_A, image_Re, image_Im, 0, 0 );
     
    	// scale image for display
    	cvMinMaxLoc(image_Re, &m, &M, NULL, NULL, NULL);
    	cvScale(image_Re, image_Re, 1.0/(M-m), 1.0*(-m)/(M-m));
     
    	image_Re->origin = src->origin;
     
     
    	for(i=0;i<dst->height;i++)
    	{
    		for(j=0;j<dst->width;j++)
    		{
    			dst->imageData[j+(i*dst->width)]=(unsigned char)((255)*(((double*)image_Re->imageData)[(j+(image_Re->width-dst->width)/2)+((i+(image_Re->height-dst->height)/2)*(image_Re->width))]));//(unsigned char)(min(255*(((double*)image_Re->imageData)[(j+(image_Re->width-dst->width)/2)+((i+(image_Re->height-dst->height)/2)*(image_Re->width))]),255));
    		}
    	}
     
    	cvSaveImage("src.bmp",src);
    	cvSaveImage("dst.bmp",dst);
    	// Compute differences image
    	cvSub(src,dst,dst,0);
    	cvSaveImage("difference.bmp",dst);

  4. #4
    Candidat au Club
    Inscrit en
    Avril 2010
    Messages
    3
    Détails du profil
    Informations forums :
    Inscription : Avril 2010
    Messages : 3
    Par défaut Code
    Bonjour,

    Est-ce que c'est possible de poster tout le programme svp.

    Merci

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 5
    Dernier message: 30/07/2014, 10h44
  2. Réponses: 82
    Dernier message: 05/02/2011, 14h34
  3. Recalculer une feuille Excel après une modif de style
    Par ThierryAIM dans le forum Macros et VBA Excel
    Réponses: 9
    Dernier message: 09/03/2007, 20h55
  4. Modification de la date d'une table possible après une MAJ?
    Par theseriallooser dans le forum InterBase
    Réponses: 1
    Dernier message: 15/02/2006, 23h03
  5. copie d'une table Y d'une base A vers une table X d'une base
    Par moneyboss dans le forum PostgreSQL
    Réponses: 1
    Dernier message: 30/08/2005, 21h24

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo