我正在尝试检测此图像中的圆圈:
然后使用 C++ 中的 DIPlib 在另一个空白图像中绘制这些圆圈。
按照 Cris Luengo 的建议,我更改了代码,现在看起来像这样:
#include <iostream>
#include <vector>
#include <diplib.h>
#include <dipviewer.h>
#include <diplib/file_io.h>
#include <diplib/display.h>
#include <diplib/color.h>
#include <diplib/linear.h>
#include <diplib/detection.h>
#include <diplib/generation.h>
using namespace std;
int main()
{
try{
//read image
dip::Image img;
dip::ImageReadTIFF(img,"circle.tif");
dip::ColorSpaceManager csm;
img = csm.Convert(img, "grey");
//circle detection
//first convert the image in binary
dip::Image bin_img = img<128;
//Now calculate the gradient vector of the images
dip::Image gv=dip::Gradient(img);
//Apply the Hough transform to find the cicles
dip::FloatCoordinateArray circles;
circles=dip::FindHoughCircles(bin_img,gv,{},0.0,0.2);
//Draw circles
dip::Image detec_img= g_img.Similar(dip::DT_UINT8);
for(auto i: circles){
dip::FloatArray center;
center.push_back(i[0]);
center.push_back(i[1]);
dip::dfloat diameter=i[2]*2;
dip::DrawBandlimitedBall(detec_img,diameter,center, {255}, "empty");
center.clear();
}
dip::ImageWriteTIFF(detec_img, "detected.tif");
我还更改了FindHoughCircles
函数的参数,因为图像中有两个同心圆,所以中心之间的距离必须为 0.0,但程序无法检测到它。这是结果: