OpenCV 里的sigma 是多少

std::vector<double> createGaussianKernal( int kernal_size , float sigma=0 )
{
    int radius = kernal_size / 2;
    //sigma = sigma > 0 ? sigma : radius*0.3 + 0.8;
    std::vector<double> kernal;// (kernal_size);

    for (int i = -radius; i != radius + 1; ++i)
    {
        double x = i;
        double val = (1.0 / (sqrt(2 * M_PI) *sigma))   *  exp((-x*x) / (2 * sigma*sigma));
        kernal.push_back(val);
    }

    double sum = 0;
    for (int i = 0; i != kernal.size(); ++i) {
        sum += kernal[i];
    }

    for (int i = 0; i != kernal.size(); ++i) {
        kernal[i] /= sum;
    }
    return kernal;
}

 

OpenCV 使用的是这个 0.2 * filterWidth 

posted @ 2022-01-14 11:54  洛笔达  阅读(92)  评论(0编辑  收藏  举报