私は現在、2 つのマトリックスの二乗距離の合計を求める作業を行っています。データは double* 配列に保持されています。それらの最初のものは同じままですが、もう一方は 2 つのインデックス間の 32x32 配列を返す関数を使用して循環します。
ただし、「e」の最初のインクリメントの後に「getTile(d、e)」を呼び出そうとすると、ヒープ破損の例外がスローされます。
double* Matrix::ssd(int i, int j, Matrix& rhs){
double sum = 0, val = 0; int g = 0, h=0;
double* bestMatch = new double[32*32]; double* sameTile = new double[32*32]; double* changeTile = new double[32*32];
for(int x = i-32; x <i; x++){
for(int y = j-32; y <j; y++){
sameTile[g*32+h] = data[x*N+y];
h++;
}g++; h = 0;
}
system("pause");
for(int d = 32; d<=512; d+=32){
for(int e = 32; e<=512; e+=32){
changeTile = rhs.getTile(d,e);
for(int out = 0; out < 32; out++){
for(int in = 0; in < 32; in++){
val = sameTile[out*32+in] - changeTile[out*32+in];
val = val*val;
sum = sum + val;
}
}
cout << sum << endl;
sum = 0; val = 0;
system("pause");
}
}
getTile(int i, int j) 関数:
double* Matrix::getTile(int i, int j){
double* tile = new double[32*32]; int g = 0; int h = 0;
for(int x=i-32; x<i; x++){
for(int y=j-32; y<j; y++){
tile[g*32+h] = data[x*N+y];
h++;
}
cout << endl;
g++;
}
return tile;
}
changeTile double* でのメモリの割り当てでエラーが発生すると思いますか?
どんな助けでも大歓迎です。