0

aquila DSP LIb を使用して、波の mfcc と dtw を計算しようとしています。しかし、次のコードを実行すると

 void main()
 {

     int frame_size =1024;

     Aquila::WaveFile waveIn0("a_converted.wav"); 
     Aquila::FramesCollection frameCollection0(waveIn0, frame_size);
     vector<vector<double>> dtwdt0;
     Aquila::Mfcc mfcc0(frame_size);

     for (int i=0; i<frameCollection0.count(); i++)
     {
         Aquila::Frame frame = frameCollection0.frame(i);
         vector<double> mfccValues = mfcc0.calculate(frame);
         dtwdt0.push_back(mfccValues);
     }

     Aquila::WaveFile waveIn1("a_converted.wav");
     Aquila::FramesCollection frameCollection1(waveIn1, frame_size);
     vector<vector<double>> dtwdt1;
     Aquila::Mfcc mfcc1(frame_size);

     for (int i = 0; i < frameCollection1.count(); i++)
     {
         Aquila::Frame frame = frameCollection1.frame(i);
         vector<double> mfccValues = mfcc1.calculate(frame);
         dtwdt1.push_back(mfccValues);
     }

     Aquila::Dtw dtw(Aquila::euclideanDistance,          Aquila::Dtw::PassType::Diagonals);
   double distance_1 = dtw.getDistance(dtwdt0, dtwdt1);
         cout << "Distance : " << distance_1 << endl;
  }

この例外が発生しました。ベクトル添字が範囲外 ファイル: c:\program files\microsoft visual studio 8\vc\include\vector 行: 1124

問題は何ですか?

4

0 に答える 0