Lam*_*amp 3 algorithm image-processing
我尝试实现一种用种子点分割图像的方法,并将每个像素分配给最近的点。
例如,如果像素接近1,则设置为1。
输入:
0 0 0 0 0 3 0
0 1 0 0 0 0 0
0 0 0 0 2 0 0
0 0 0 0 0 0 0
Run Code Online (Sandbox Code Playgroud)
输出:
1 1 1 3 3 3 3
1 1 1 2 2 3 3
1 1 1 2 2 2 2
1 1 1 2 2 2 2
Run Code Online (Sandbox Code Playgroud)
目前的方法需要太长的时间并计算(width * height * numPoints)次,有没有任何算法可以更快?
7秒处理5 9478 * 1868张图像,numPoints = 8
for (int i = 0; i < height; i++)
{
for (int j = 0; j < width; j++)
{
byte index = 0;
double distance = double.MaxValue;
for (int m = 0; m < elements.Count; m++)
{
CircleROI circle = roiResized[m];
double currentDistance = Math.Abs(i - circle.Center.Y) +
Math.Abs(j - circle.Center.X);
if (currentDistance < distance)
{
distance = currentDistance;
index = (byte)m;
}
}
*data++ = index;
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
146 次 |
| 最近记录: |