otsu阈值分割算法原理_阈值分割-Otsu法

本文通过C++实现Otsu阈值分割算法,详细展示了算法的步骤,包括读取灰度图像、计算像素级个数、遍历阈值找到最优分割点,最终得出图像的阈值和最大类间方差。
摘要由CSDN通过智能技术生成

算法实现(不调用函数)

#include

#include

using namespace std;

using namespace cv;

//实现灰度直方图的绘制

void drawpicture(Mat &inpicture, Mat &outpicture)

{

MatND hist;

const int bins = 256;

int hist_size[] = { bins };

float range[] = { 0, 256 };

const float* ranges[] = { range };

int channels[] = { 0 };

calcHist(&inpicture, 1, channels, Mat(), hist, 1, hist_size, ranges, true, false);

double maxnum;

minMaxLoc(hist, 0, &maxnum, 0, 0);

int scale = 1;

int histheight = 256;

for (int i = 0; i < bins; i++)

{

float binvalue = hist.at(i);

int height = cvRound(binvalue*histheight / maxnum);

// 绘制长方形

rectangle(outpicture, Point(i*scale, histheight), Point((i + 1)*scale, histheight

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值