-1

フォーラムのヘルプ コードを使用して、興味のない 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

誰かがこのコードの作成を手伝ってくれますか..ありがとう

4

1 に答える 1