2017-04-19 5 views
-1

私は、Microsoft Visual C++ 2010(32ビットシステム)に取り組んできましたがC++エラー:「WindowsはEspectrogramafrequencia.exeにブレークポイントをトリガした」

コンパイルフェーズは大丈夫ですが、実行時に私が取得します

"WindowsがEspectrogramafrequencia.exeでブレークポイントをトリガしました。これは、Espectrogramafrequencia.exeまたはロードしたDLLのバグを示すヒープの破損が原因である可能性があります。 [Break] [CONTINUE] [IGNORE] "

このページの先頭へ戻るこの資料は以下の製品について記述したものです。

コード:

#include "StdAfx.h" 
#include <stdlib.h> 
#include <stdio.h> 
#include <time.h> 
#include <fftw3.h> 
#include <iostream> 
#include <cmath> 
#include <fstream> 

using namespace std; 

int main() 
{ 
int i; 
const int N=550;//Number of points acquired inside the window 
double Fs=200;//sampling frequency 
double dF=Fs/N; 
double T=1/Fs;//sample time 
double f=50;//frequency 
double *in; 
fftw_complex *out; 
double t[N];//time vector 
double ff[N]; 
fftw_plan plan_forward; 
in = (double*) fftw_malloc(sizeof(double) * N); 
out = (fftw_complex*) fftw_malloc(sizeof(fftw_complex) * N); 
for (int i=0; i<= N;i++) 
{ 
t[i]=i*T; 
double M_PI=3.14159265359; 
in[i] =0.7 *sin(2*M_PI*f*t[i]);// generate sine waveform 
double multiplier = 0.5 * (1 - cos(2*M_PI*i/(N-1)));//Hanning Window 
in[i] = multiplier * in[i]; 
} 
for (int i=0; i<= ((N/2)-1);i++){ 
ff[i]=Fs*i/N;} 
plan_forward = fftw_plan_dft_r2c_1d (N, in, out, FFTW_ESTIMATE); 
fftw_execute (plan_forward); 
double v[N]; 
for (int i = 0; i<= ((N/2)-1); i++){ 
v[i]=(20*log(sqrt(out[i][0]*out[i][0]+ out[i][1]*out[i][1])))/N; //Here I have calculated the y axis of the spectrum in dB 
} 
fstream fichero; 
fichero.open("example2.txt",fstream::out);//fichero.open("example2.txt"); 
fichero << "plot '-' using 1:2" << std::endl;//fichero << "plot '-' using 1:2" << endl; 
for(i = 0;i< ((N/2)-1); i++){ 
fichero << ff[i]<< " " << v[i]<< std::endl; 
} 
fichero.close(); 
fftw_destroy_plan (plan_forward); 
fftw_free (in); 
fftw_free (out); 
return 0; 
} 

はあなたにこのエラーが何を意味するかのいずれかのアイデアをお持ちですか? 「ヒープの破損」とはどういう意味ですか?

助けてください

ありがとうございました!

+3


のようなforループを使用してください。あなたのインデックス作成を見てください。 – molbdnilo

+3

for(int i = 0; i <= N; i ++)のループインデックスは疑わしいです。つまり、 'N + 1 '回反復することになります。これは、' N'要素のブロックを扱う場合には悪いニュースです。 –

+0

ありがとうPhil Brubaker –

答えて

1

t[]のメモリ制限を超えている値を割り当てようとしています。
C++配列はゼロベースのインデックスなので、配列t[]のインデックス範囲は0..549です。あなたが動的に割り当てられた何かの近くに、あなたはなかったいくつかのメモリを変更した

for (int i=0; i< N;i++) 
関連する問題