Расчет кривой Гаусса (C ++) - PullRequest
       35

Расчет кривой Гаусса (C ++)

0 голосов
/ 20 февраля 2019

С учетом гистограммы выполните подгонку Гаусса с двумя значениями.Этот проект помещает две гауссовские кривые в одну гистограмму с начальным пороговым значением и использует кривые для определения идеального порогового значения.На каждой итерации гистограмма делится на 2 части, для каждой части гистограммы вызывается гауссиан.

Мои вычисления должны быть неверными, учитывая, что моя результирующая кривая не имеет смысла.Кто-нибудь может определить, что здесь происходит?Я включил свои функции для вычисления гауссовой кривой biMeans, fitGauss (вычисляет кривую Гаусса), среднее значение, дисперсию и значение Гаусса.

int biMeanGauss (int thrVal){
    double sum1, sum2, total = 0.0;
    int bestThr = thrVal;
    double minDiff = 99999999.0;

    for (int i = thrVal; i < (maxVal-offSet); i++) {
        set1DZero(GaussAry);

        sum1 = fitGauss(0, i);
        cout << "Sum1: " <<sum1 << endl;
        sum2 = fitGauss(i, maxVal);
        cout << "Sum2: " << sum2 << endl;
        total = sum1 + sum2;
        cout << "Total: " << total << endl;

        if (total < minDiff) {
            minDiff = total;
            bestThr = i; 
            cout << "Total < MinDiff, so BestThr: " <<bestThr << endl;
        }
        else;
    }
    return bestThr;
}

double fitGauss(int leftIndex, int rightIndex){
    double mean, var, sum = 0.0;
    double Gval;

    mean = computeMean(leftIndex, rightIndex, maxCount);
    var = computeVar (leftIndex, rightIndex, mean);

    for (int index = leftIndex; index <= rightIndex; index ++){
        Gval = computeGaussian(histAry[index], mean, var);
        sum += abs(Gval - histAry[index]);
        GaussAry[index] = (int)Gval;
        GaussImg[index][(int)Gval]= 1;
    }

    return sum;
};

double computeMean(int leftIndex, int rightIndex, int maxCount) {
    int mean, n, sum = 0;
    for (int i = leftIndex; i <= rightIndex; i++){
        sum += (i*histAry[i]);
        n++;
        if (histAry[i] > maxCount){
            maxCount = histAry[i];
        }
    }
    mean = (sum / (double) n);
    return mean;
}

double computeVar(int leftIndex, int rightIndex, int mean) {
    double var = 0;
    double sum = 0;
    double n = 0;

    for (int i = leftIndex; i <= rightIndex; i++) {
        sum += histAry[i]*(i - mean) * (i - mean);
        n++;
    }

    var = (sum / n);
    return var;
}

double computeGaussian(int index, double mean, double var) {
    double Gval = 0;
    Gval = maxCount * exp(-(((index - mean)*(index - mean)) / (2 * var)));
    return Gval;
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...