在 opencv (java) 中是否有等效的 'smoothstep' 函数?它通常用于 opengl/glsl 并且在许多其他标准图像处理库中作为标准内置函数提供。也许我们可以使用组合来实现它阈值/钳位功能。将 smoothstep 函数与 opencv mat 对象一起使用的最佳或最有效的方法是什么?
这是一个示例代码:-
float smoothstep(float edge0, float edge1, float x) {
// Scale, bias and saturate x to 0..1 range
x = clamp((x - edge0) / (edge1 - edge0), 0.0f, 1.0f);
// Evaluate polynomial
return x * x * (3 - 2 * x);
}
float clamp(float x, float lowerlimit, float upperlimit) {
if (x < lowerlimit)
x = lowerlimit;
if (x > upperlimit)
x = upperlimit;
return x;
}
Imgproc.GaussianBlur(mskmat, mskmat,new org.opencv.core.Size(3,3), 0);
Utils.matToBitmap(mskmat,bitmap);
save(bitmap,"mask");
//Smoothing
mskmat.convertTo(mskmat,CV_32F);
for (int i=0; i<mskmat.rows(); i++)
{
for (int j=0; j<mskmat.cols(); j++)
{
double[] data = mskmat.get(i, j); //Stores element in an array
for (int k = 0; k < 1; k++) //Runs for the available number of channels
{
data[k] = 255.0f * smoothstep(0.3f,0.5f, (float)data[k]/255.0f); //Pixel modification done here
}
Log.d("Value", Arrays.toString(data));
mskmat.put(i, j, data); //Puts element back into matrix
}
}
mskmat.convertTo(mskmat,CV_8U);
Utils.matToBitmap(mskmat,bitmap);
save(bitmap,"smoothmask");
但是这种方法似乎太慢了,输出不如标准的smoothstep函数好。