フォーラムのヘルプ コードを使用して、興味のない KNN アルゴリズムを実装しようとしています。コードは次のとおりです。
#include <opencv\cv.h>
#include <opencv\ml.h>
#include <opencv\highgui.h>
#include <opencv\cxcore.h>
#include <iostream>
#include <stdlib.h>
#include <stdio.h>
#include <time.h>
using namespace std;
using namespace cv;
//typedef unsigned char BYTE;
int readFlippedInteger(FILE *);
int main()
{
FILE *fp = fopen("D:\\KNN\\train-images.idx3-ubyte", "rb");
FILE *fp2 = fopen("D:\\KNN\\train-labels.idx1-ubyte", "rb");
if(!fp || !fp2)
{
cout<<"Files not Found"<<endl;
return 0;
}
int magicNumber = readFlippedInteger(fp);
int numImages = readFlippedInteger(fp);
int numRows = readFlippedInteger(fp);
int numCols = readFlippedInteger(fp);
fseek(fp2, 0x08, SEEK_SET);
int size = numRows*numCols;
CvMat *trainingVectors = cvCreateMat(numImages, size, CV_32FC1);
CvMat *trainingLabels = cvCreateMat(numImages, 1, CV_32FC1);
//BYTE *temp = new BYTE[size];
unsigned char *temp = (unsigned char *) malloc(size);
unsigned char tempClass=0;
for(int i=0; i < numImages; i++)
{
fread((void*)temp, size, 1, fp);
fread((void*)(tempClass), sizeof(unsigned char*), 1, fp2);
trainingLabels->data.fl[i] = tempClass;
for(int k=0; k < size; k++)
trainingVectors->data.fl[i*size+k] = temp[k];
}
KNearest knn(trainingVectors, trainingLabels);
printf("Maximum k: %d\n", knn.get_max_k());
fclose(fp);
fclose(fp2);
cvReleaseMat(&trainingVectors);
cvReleaseMat(&trainingLabels);
return 0;
}
int readFlippedInteger(FILE *fp)
{
int ret = 0;
unsigned char *temp;
temp = (unsigned char*)(ret);
fread(&temp[3], sizeof(unsigned char*), 1, fp);
fread(&temp[2], sizeof(unsigned char*), 1, fp);
fread(&temp[1], sizeof(unsigned char*), 1, fp);
fread(&temp[0], sizeof(unsigned char*), 1, fp);
return ret;
}
BYTE の代わりに unsigned char を使用しましたが、これも同じように機能すると思います。ここで間違っている場合は修正してください。
それにもかかわらず、私はプログラミングの専門家ではありませんが、コードを実行するとこのエラーが発生します
* K-Nearest Neighbour.exe の 0x000007FEE68F7450 (msvcr110d.dll) で未処理の例外: 0xC0000005: アクセス違反書き込み場所 0x0000000000000003
誰かがこのコードの作成を手伝ってくれますか..ありがとう