chan-vese模型
Python--level set (水平集)和 chan-vese模型
level set :https://www.zhihu.com/question/22608763?sort=created
https://blog.csdn.net/xiangyong58/article/details/11876019
chan-vese模型(公式推导):https://blog.csdn.net/zhangchen1003/article/details/48930377
水平集(CV模型)代码:
- import cv2
- from pylab import*
- Image = cv2.imread('02.jpg', 1) # 读入原图
- image = cv2.cvtColor(Image, cv2.COLOR_BGR2GRAY)
- img = np.array(image, dtype=np.float64) # 读入到np的array中,并转化浮点类型
- # 初始水平集函数
- IniLSF = np.ones((img.shape[0], img.shape[1]), img.dtype)
- IniLSF[300:320, 300:320] = -1
- IniLSF = -IniLSF
- # 画初始轮廓
- Image = cv2.cvtColor(Image, cv2.COLOR_BGR2RGB)
- plt.figure(1), plt.imshow(Image), plt.xticks([]), plt.yticks([]) # to hide tick values on X and Y axis
- plt.contour(IniLSF, [0], color='b', linewidth=2) # 画LSF=0处的等高线
- plt.draw(), plt.show(block=False)
- def mat_math(intput, str):
- output = intput
- for i in range(img.shape[0]):
- for j in range(img.shape[1]):
- if str == "atan":
- output[i, j] = math.atan(intput[i, j])
- if str == "sqrt":
- output[i, j] = math.sqrt(intput[i, j])
- return output
- # CV函数
- def CV(LSF, img, mu, nu, epison, step):
- Drc = (epison / math.pi) / (epison*epison + LSF*LSF)
- Hea = 0.5*(1 + (2 / math.pi)*mat_math(LSF/epison, "atan"))
- Iy, Ix = np.gradient(LSF)
- s = mat_math(Ix*Ix+Iy*Iy, "sqrt")
- Nx = Ix / (s+0.000001)
- Ny = Iy / (s+0.000001)
- Mxx, Nxx = np.gradient(Nx)
- Nyy, Myy = np.gradient(Ny)
- cur = Nxx + Nyy
- Length = nu*Drc*cur
- Lap = cv2.Laplacian(LSF, -1)
- Penalty = mu*(Lap - cur)
- s1 = Hea*img
- s2 = (1-Hea)*img
- s3 = 1-Hea
- C1 = s1.sum() / Hea.sum()
- C2 = s2.sum() / s3.sum()
- CVterm = Drc*(-1 * (img - C1)*(img - C1) + 1 * (img - C2)*(img - C2))
- LSF = LSF + step*(Length + Penalty + CVterm)
- # plt.imshow(s, cmap ='gray'),plt.show()
- return LSF
- # 模型参数
- mu = 1
- nu = 0.003 * 255 * 255
- num = 20
- epison = 1
- step = 0.1
- LSF = IniLSF
- for i in range(1, num):
- LSF = CV(LSF, img, mu, nu, epison, step) # 迭代
- if i % 1 == 0: # 显示分割轮廓
- plt.imshow(Image), plt.xticks([]), plt.yticks([])
- plt.contour(LSF, [0], colors='r', linewidth=2)
- plt.draw(), plt.show(block=False), plt.pause(0.01)
为什么上传图片这么麻烦。
一、文章参考
Chan T F, Vese L. Active contours without edges[J]. Image processing, IEEE transactions on, 2001, 10(2): 266-277.
1
二、公式推导过程
---------------------
作者:jonson_zc
来源:CSDN
原文:https://blog.csdn.net/zhangchen1003/article/details/48930377
版权声明:本文为博主原创文章,转载请附上博文链接!
chan-vese模型的更多相关文章
- Vuforia开发完全指南---不懂编程也能做AR程序
不懂编程也能做AR程序 可能一听到要做AR程序,很多人都会想到这是程序员的事.如果不懂编程,不会写代码,是做不了AR程序的.其实,Vuforia的Unity SDK非常人性化,即使你不会编程,也能做出 ...
- Active Snake (Level Set 模型)
前沿:最近由于大论文实验的原因,需要整理几种Snake方法,以比较道路提取效果.所以今天晚上就将电脑中的一些LBF Snake代码作一下分类定义.并给出效果.以便比较. 1. 原始的LBF Snake ...
- NS2仿真:公交车移动周期模型及性能分析
NS2仿真实验报告3 实验名称:公交车移动周期模型及性能分析 实验日期:2015年3月16日~2015年3月21日 实验报告日期:2015年3月22日 一.实验环境(网络平台,操作系统,网络拓扑图) ...
- 【Unity Shader】Unity Chan的卡通材质
写在前面 时隔两个月我终于来更新博客了,之前一直在学东西,做一些项目,感觉没什么可以分享的就一直没写.本来之前打算写云彩渲染或是Compute Shader的,觉得时间比较长所以打算先写个简单的. 今 ...
- (转)Go语言并发模型:使用 context
转载自:https://segmentfault.com/a/1190000006744213 context golang 简介 在 Go http包的Server中,每一个请求在都有一个对应的 g ...
- go 语言之 生产者消费模型
简易的生产者消费模型,通过管道[也可以理解为队列],管道是先进先出,主要是理解chan 生产者使用make将chan初始化,并且设置chan长度,如果不设置,生产者就写入不了通道 go 是使用线程开始 ...
- Unity Chan 3D Asset
Unity Chan 3D Asset 我真的很久沒再家裡開unity,不過今天让我久违的開了 下载地址 :http://ref.gamer.com.tw/redir.php?url=http%3A ...
- golang学习笔记 ---面向并发的内存模型
Go语言是基于消息并发模型的集大成者,它将基于CSP模型的并发编程内置到了语言中,通过一个go关键字就可以轻易地启动一个Goroutine,与Erlang不同的是Go语言的Goroutine之间是共享 ...
- 11 The Go Memory Model go语言内置模型
The Go Memory Model go语言内置模型 Version of May 31, 2014 Introduction 介绍 Advice 建议 Happens Before 在发生之前 ...
随机推荐
- VUE - 引入 npm 安装的模块 以及 uuid模块的使用
<template> <div> <form @submit.prevent="addTodo"> <in ...
- 018、MySQL取满足日期在两个日期之间的所有数据
#查询 SELECT GZJK_CREATEDATE FROM abc_table WHERE ( ( GZJK_CREATEDATE >= UNIX_TIMESTAMP( '2019-08-0 ...
- 如何让你的学术Essay写作看起来更高级?
学术风格不仅是使用某些特定的词汇或者特定的表达方式.学术风格还会涉及到你的思考方式.推理方式以及你如何利用某个领域内已知的发现.学术风格是英国大学学习的核心.所以在平时的学习中,英国环球论文小编建议大 ...
- [题解] LuoguP4091 [HEOI2016/TJOI2016]求和
传送门 首先我们来看一下怎么求\(S(m,n)\). 注意到第二类斯特林数的组合意义就是将\(m\)个不同的物品放到\(n\)个没有区别的盒子里,不允许有空盒子的方案数. 那么将\(m\)个不同的物品 ...
- poj 2456 Aggressive cows 贪心+二分
Aggressive cows Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 25944 Accepted: 11982 ...
- Asp.net mvc项目分页功能
1.定义一个分页用的Page<T>类 /* 使用示例: var pager = new Pager<Article>( this.ControllerContext, //上下 ...
- django 实现 内网访问 和 用花生壳进行内网穿透
1.在setting.py中找到 ALLOWED_HOSTS = [] 改为 ALLOWED_HOSTS = ['*',]2.启动服务时使用如下命令行 python .\manage.py runs ...
- Ajax学习系列——Ajax介绍及优缺点
一.什么是Ajax Ajax即“Asynchronous JavaScript And XML”(异步JavaScript和XML),是一种创建交互式网页应用的网页开发技术. Ajax = 异步Jav ...
- 分享一个php加密字符串类。
class base64{ /** * 加密字符串 * @access static * @param string $data 字符串 * @param string $key 加密key * @r ...
- 第二阶段scrum-4
1.整个团队的任务量: 2.任务看板: 会议照片: 产品状态: 前端制作完成,数据库在制作中.