时间:2020-12-07
算法流程:
p(x0,y0)
,用堆栈表示种子区域,将种子点push
到种子堆栈中;pop
出堆栈,并以该点为中心,遍历该中心8邻域像素;continue
;p(x,y)
和种子区域的均值refAvg
灰度差是否满足阈值;若满足,将p(x, y)
push
到堆栈中;若不满足,continue
;refAvg
,找出离上一个种子"最近"的seed
,更新堆栈顺序;源码v1.0
,目前存在的问题是:
生长过程中,以下代码只会寻找下一个种子(仅一个),取决于迭代的顺序。最终,可能导致分割效果不同。
另一个问题是阈值的选择问题。
修改策略:自适应阈值?全局迭代?后续补充v2.0
。
int negihborRegionCheck(
unsigned char *pSrc,
unsigned char *pDst,
seedInfo_t *seedPts,
unsigned int *seedCnt,
imageSize_t srcSize,
unsigned char threshold
) {
if (nullptr == pSrc || nullptr == pDst || nullptr == seedPts || nullptr == seedCnt ||
srcSize.width <= 0 || srcSize.height <= 0) {
// input err.
return -1;
}
// malloc buffer for seed list.
seedInfo_t *listSeedPts = (seedInfo_t *)malloc(sizeof(seedInfo_t) * MAX_SEED_NUM);
// get seedPts[]
memcpy(listSeedPts, seedPts, sizeof(seedInfo_t) * (*seedCnt));
// get 1-st seed pts.
int numRegSeedList = *seedCnt;
int resBoundary = 0;
int nbPts[8][2] = { {-1, -1},
{ 0, -1},
{ 1, -1},
{-1, 0},
{ 1, 0},
{-1, 1},
{ 0, 1},
{ 1, 1} };
// get region mean.
float refAvg = listSeedPts[0].var;
while (numRegSeedList > 0) {
#ifdef ENABLE_OPENCV
cv::Mat ori(srcSize.height, srcSize.width, CV_8UC1, (void *)pSrc);
cv::Mat dst(srcSize.height, srcSize.width, CV_8UC1, (void *)pDst);
#endif
// pop a seed.
int x = listSeedPts[0].pts.x;
int y = listSeedPts[0].pts.y;
pDst[y * srcSize.width + x] = 255; // mark seed.
// iter stack.
for (int k = numRegSeedList - 1; k > 0; k--) {
listSeedPts[k - 1] = listSeedPts[k];
}
listSeedPts[numRegSeedList - 1].pts.x = 0;
listSeedPts[numRegSeedList - 1].pts.y = 0;
listSeedPts[numRegSeedList - 1].var = 0;
numRegSeedList -= 1;
for (int i = 0; i < 8; i++) {
unsigned int xn = x + nbPts[i][0];
unsigned int yn = y + nbPts[i][1];
resBoundary = ((xn >= 0) && (xn <= srcSize.width - 1) &&
(yn >= 0) && (yn <= srcSize.height - 1));
if (resBoundary && pDst[yn * srcSize.width + xn] == 0) {
if (fabs(pSrc[yn * srcSize.width + xn] - refAvg) <= threshold) {
pDst[yn * srcSize.width + xn] = 255;
// add seed to list, push pts in stack.
listSeedPts[numRegSeedList].pts.x = xn;
listSeedPts[numRegSeedList].pts.y = yn;
listSeedPts[numRegSeedList].var = pSrc[yn * srcSize.width + xn];
numRegSeedList += 1;
}
}
}
// find next seed.
int idx = 0;
int minVar = 255;
float sumReg = pSrc[y * srcSize.width + x];
for (int i = 0; i < numRegSeedList; i++) {
if (minVar >= fabs(pSrc[y * srcSize.width + x] - listSeedPts[i].var)) {
minVar = fabs(pSrc[y * srcSize.width + x] - listSeedPts[i].var);
idx = i;
}
sumReg += listSeedPts[i].var;
}
if (sumReg > 0 && numRegSeedList > 0) {
refAvg = sumReg / (numRegSeedList + 1);
}
// update list (swap element).
if (idx > 0) {
int tempVar = listSeedPts[0].var;
int tempX = listSeedPts[0].pts.x;
int tempY = listSeedPts[0].pts.y;
listSeedPts[0].var = listSeedPts[idx].var;
listSeedPts[0].pts.x = listSeedPts[idx].pts.x;
listSeedPts[0].pts.y = listSeedPts[idx].pts.y;
listSeedPts[idx].var = tempVar;
listSeedPts[idx].pts.x = tempX;
listSeedPts[idx].pts.y = tempY;
}
}
if (listSeedPts) {
free(listSeedPts);
}
return 0;
}
文章浏览阅读436次,点赞15次,收藏2次。原因或许是,使用autofocus时,确实聚焦了!但是当我们又点击 显示弹出框的按钮时,input又失焦了,所以当我们看到input框时,没有自动聚焦。_vue3 el-input 自动聚焦autofocus无效
文章浏览阅读222次。《《说课稿LINUX》PPT课件.ppt》由会员分享,可在线阅读,更多相关《《说课稿LINUX》PPT课件.ppt(16页珍藏版)》请在装配图网上搜索。1、LINUX 基础应用与配置管理 桂林山水职业学院计算机系 朱笑雷 主要内容 课程定位 1 课程内容设置 2 教学方法与手段 3 教材建设 4 教学团度 5 主要内容 实践条件 6 课程考核 7 教学效果 8 课程特色 9 建设思路 10 一、课..._linux说课课件
文章浏览阅读2.2k次。#在SpringBoot中启动时关于连接数据库失败的问题对照了application.yml,发现配置文件貌似没什么问题,但是在查找信息之后,发现问题正是出现在application.yml中问题出于datasource下的data-username和data-password只要将data-username和data-password改为username和password即可..._springboot启动时数据库连接失败 不关闭
文章浏览阅读4.6k次。一般情况下登录系统后菜单是由后端返回的,不是前端写死的。antd-pro也支持,修改的路径在app.tsx在 layout 里加一个menuDataRender字段先给一个() =>[]可以看到左侧菜单没了,说明配置生效了,接下来就可以围绕这个配置做文章了,我们先定义一个 menuDataRender方法。根据登录缓存到本地的数据做下处理,判断菜单里要展示哪些内容(比如替换字段,隐藏不显示的菜单,隐藏按钮等),处理好了后返回一个数组结构即可。示例代码如下export const layout: _antdpro的菜单
文章浏览阅读77次。为什么80%的码农都做不了架构师?>>> ..._jprofiler6 key
文章浏览阅读170次。(可以看出递归算法更加侧重于计算的技巧,并且计算机计算的次数也相对更少);_c语言程序设计第四版课后题答案苏小红第七章
文章浏览阅读4.4w次,点赞8次,收藏51次。浏览器抓包(工具:fiddler)并 修改请求内容 工具下载:https://pan.baidu.com/s/1pyKdAwgTdNNvoWA2bGlk9A 1、正常打开网页,输入要提交的内容 2、打开工具,f11暂停了页面的所有提交动作 3、这时再点击提交按钮,请求的数据就会被工具拦截 4、双击截取的数据,右侧会看到请求的具体内容,任意修改数据 5、点击绿色按钮 run ..._filder改数据包
文章浏览阅读560次。如果您想在计算机或任何其他设备上播放高质量的视频,高清视频转换器可以帮助确保您的视频与您的操作系统和硬件兼容。您还可以使用高清转换器更改视频的分辨率,无论您是想提高质量还是降低分辨率以生成更小的文件。在下表中,我们描述了用于转换高清视频的最流行和可用的桌面程序和在线服务。它们各有优缺点,因此请根据您的需要进行选择。_奇客视频转换
文章浏览阅读1.9k次。欢迎来到unity学习、unity培训、unity企业培训教育专区,这里有很多U3D资源、U3D培训视频,我们致力于打造业内unity3d培训、学习第一品牌。今天开始做我们的游戏了,组长给分配了任务,我负责做剧情动画,人物血条和种植植物。 一、剧情动画 动画是以多个图片的形式展现的,图片是自己制作的。 private GUITextu_游戏血条动图
文章浏览阅读1k次。*******字符编码ASCII,GB2312,GBK,Unicode,UTF-8比较参考:https://blog.csdn.net/softwarenb/article/details/51994943**环境变量的加载顺序:Mac系统的环境变量,加载顺序为:a. /etc/profileb. /etc/pathsc. ~/.bash_profiled. ~/..._环境变量的顺序
文章浏览阅读316次。▼大型年度AI人物评选——2017中国AI英雄风云榜已于12月4日在乌镇张榜,12月18日在北京国贸三期举行颁奖典礼。榜单评选出年度技术创新人物TOP 10;商业创新人物TOP 10,获取完整榜单请关注网易智能公众号(ID:smartman163),回复关键词“评奖”。本文系网易智能工作室出品聚焦AI,读懂下一个大时代【网易智能讯12月10日消息】不只有你会_人类大脑植入代码
文章浏览阅读3.6k次。几经研究, 终于实现了。time[2020-06-04 11:43:36](?<=\[)(.*)(?=])(pattern) 匹配 pattern 并获取这一匹配。所获取的匹配可以从产生的 Matches 集合得到,在VBScript 中使用 SubMatches 集合,在JScript 中则使用 $0…$9 属性。要匹配圆括号字符,请使用 '\(' 或 '\)'。 (?:pattern) 匹配 pattern 但不获取匹配结..._正则<>里内容