2018-01-15 椭圆检测与拟合

椭圆检测与拟合

欢迎到YangHan's Notebook 椭圆检测与拟合 获得更佳阅读体验。

实验目标

  • 调⽤CvBox2D cvFitEllipse2( const CvArr* points )实现椭圆拟合

实验环境

  • Windows 10 1709
  • OpenCV 3.3

实验过程

实现了一个fitEllipse()函数,函数原型如下:

void fitEllipse(char* filename, int threshold);

传入图片路径,然后显示出图片椭圆拟合之后的效果。

支持命令行解析图片路径参数。

FitEllipse.exe  test.png

如果没有路径参数,默认时当前目录下的test.png

首先把图片读进来,包括一份灰度图和一份原图。

Mat gray_img = imread(filename, IMREAD_GRAYSCALE);
Mat result = imread(filename);

把灰度图二值化:

Mat binary_img = gray_img >= thresh;

然后使用findContours()检测二值化图像的轮廓点。

findContours(binary_img, contours, RETR_LIST, CHAIN_APPROX_NONE);

其中,参数3可以取值为:

  • RETR_EXTERNEL: 只检测最外围轮廓,包含在外围轮廓内的内围轮廓被忽略
  • RETR_LIST: 检测所有的轮廓,包括内围、外围轮廓,但是检测到的轮廓不建立等级关系,彼此之间独立,没有等级关系,这就意味着这个检索模式下不存在父轮廓或内嵌轮廓
  • RETR_CCOMP: 检测所有的轮廓,但所有轮廓只建立两个等级关系,外围为顶层,若外围内的内围轮廓还包含了其他的轮廓信息,则内围内的所有轮廓均归属于顶层
  • RETR_TREE: 检测所有轮廓,所有轮廓建立一个等级树结构。外层轮廓包含内层轮廓,内层轮廓还可以继续包含内嵌轮廓。

这里我们只选择RETR_LIST即可满足椭圆拟合的要求。

参数4可以取值为:

  • CHAIN_APPROX_NONE 保存物体边界上所有连续的轮廓点到contours向量内
  • CHAIN_APPROX_SIMPLE 仅保存轮廓的拐点信息,把所有轮廓拐点处的点保存入contours向量内,拐点与拐点之间直线段上的信息点不予保留
  • CHAIN_APPROX_TC89_L1, CHAIN_APPROX_TC89_KCOS: 使用teh-Chin Chain 近似算法

这里直接选择简单的CHAIN_APPROX_NONE

然后对于检测出的轮廓点,用椭圆去拟合:

for each (auto contour in contours)
{
  if (contour.size() < 6) continue;
  RotatedRect box = fitEllipse(contour);
  ellipse(result, box, Scalar(0, 255, 255), 1, LINE_AA);
}

椭圆的拟合至少需要6个点,所以把少于6个点的检测结果直接丢弃,然后对于剩下的点用cv2::fitEllipse()来拟合,然后把椭圆绘制在原图上。

之后再保存结果就行了。

实验结果

原图:

test.png

结果:

result.png

可以看到椭圆基本上都检测并拟合出来了。

心得体会

这次实验就是先检测出图像的轮廓点,然后用fitEllipse()函数来拟合椭圆,整体不是太难。然后注意到一点就是imread()读入图片的时候第二个参数可以选择读入的模式,可以用IMREAD_GRAYSCALE让其读入单通道的图片矩阵数据。

附:源代码

// main.cpp
#include <opencv2/opencv.hpp>
#include <iostream>
using namespace std;
using namespace cv;

void fitEllipse(char* filename, int threshold);

int main(int argc, char** argv) {
    char* filename;

    if (argc == 2) {
        filename = argv[1];
    }
    else {
        filename = "test.png";
    }


    fitEllipse(filename, 150);
    cvWaitKey(0);
    destroyAllWindows();

    return 0;
}


void fitEllipse(char* filename, int thresh) {

    Mat gray_img = imread(filename, IMREAD_GRAYSCALE);
    Mat result = imread(filename);
    vector<vector<Point>> contours;
    Mat binary_img = gray_img >= thresh;
    findContours(binary_img, contours, RETR_LIST, CHAIN_APPROX_NONE);
    for each (auto contour in contours)
    {
        if (contour.size() < 6) continue;
        RotatedRect box = fitEllipse(contour);
        ellipse(result, box, Scalar(0, 255, 255), 1, LINE_AA);
    }

    imwrite("result.png", result);
    imshow(filename, gray_img);
    imshow("result", result);
}

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 198,932评论 5 466
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,554评论 2 375
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 145,894评论 0 328
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,442评论 1 268
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,347评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 47,899评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,325评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,980评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,196评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,163评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,085评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,826评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,389评论 3 302
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,501评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,753评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,171评论 2 344
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,616评论 2 339

推荐阅读更多精彩内容