2013-04-25 3 views
0

Я пытаюсь взять БПФ из двух необработанных изображений. Но я получаю unhandled exception (access violation) - Я не мог понять, почему. Я использую библиотеку fftw. Сначала я читаю два изображения, затем вычисляю FFT. Но прежде чем он начнет вычислять, он вызывает ошибку нарушения доступа.Нарушение прав доступа при попытке вычислить FFT (быстрое преобразование Фурье) из 2 изображений

#include "stdafx.h" 
#include <iostream> 
#include <conio.h> 
#include "fftw3.h" 

#define Width 2280 
#define Height 170 

unsigned char im2[170*2280]; 
unsigned char im1[170*2280]; 
float image1[170*2280]; 
float image2[170*2280]; 

using namespace std; 

int _tmain(int argc, _TCHAR* argv[]) 
{ 

    FILE* fp1, *fp2; 

    //Read two images 

    fp1 = fopen ("image1.raw" , "r"); 
    fread(im1, sizeof(unsigned char), Width* Height, fp1); 

    fp2 = fopen ("image2.raw" , "r"); 
    fread(im2, sizeof(unsigned char), Width* Height, fp2); 


    fclose(fp2); 
    fclose(fp1); 

    //Typecasting two images into float 

    for (int i = 0; i < Width* Height; i++) 
    {  
     image1[i]= (float)im1[i]; 
     image2[i] = (float)im2[i]; 

    } 

    fftwf_plan fplan1, fplan2; 
    fftwf_complex fft1[((Width/2)+1)*2]; 
    fftwf_complex fft2[((Width/2)+1)*2]; 

    fplan1 = fftwf_plan_dft_r2c_2d(Height, Width, (float*)image1, fft1, FFTW_ESTIMATE); 
    fftwf_execute(fplan1); 
    fftwf_destroy_plan(fplan1); 

    fplan2 = fftwf_plan_dft_r2c_2d(Height,Width, image2, (fftwf_complex*)fft2, FFTW_ESTIMATE); 
    fftwf_execute(fplan2); 
    fftwf_destroy_plan(fplan2); 

    _getch(); 
    return 0; 
} 
+2

Какая строка дает вам ошибку нарушения доступа? – Pace

+0

@lightalchemist .raw файлы. Файлы с только пиксельными данными очень распространены в приложениях обработки изображений. – denver

+0

@Pace: строка fftwf_execute (fplan1); дает мне ошибку. – MShah

ответ

4

fft1 и fft2 только достаточно большой, чтобы держать один выходной строки - вам нужно Height строки. Вы, вероятно, захотите также распределить их динамически, поскольку они, скорее всего, будут слишком большими для стека, если у вас есть правильный размер, например.

fftwf_complex *fft1 = new fftwf_complex[((Width/2)+1)*2*Height]; 
fftwf_complex *fft2 = new fftwf_complex[((Width/2)+1)*2*Height]; 

NB: не забудьте позвонить delete [] освободить их позже.

+1

большое вам спасибо! это помогло :) – MShah