前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >能量最小化初探,graphcuts能量最小化调用

能量最小化初探,graphcuts能量最小化调用

作者头像
流川疯
发布2019-01-18 15:27:12
9890
发布2019-01-18 15:27:12
举报

  梯度下降

  模拟退火

  图割

2.这个 跟最优化问题的求解,有什么联系跟区别呢?

基本上差不多,其实就是求出来了函数的一个最小值,我们看问题的时候不妨把能量二字去掉。单纯的理解为函数

3.这个能量的观点是否跟信息熵类似,让系统的熵最小?

其实也都差不多,都是求最小值的。

我们可以看到下面的代码就求出来了相关表达式,在x =0 ,y = 1, z= 1时候能够取得最小值。

代码语言:javascript
复制
/* energy.h */
/* Vladimir Kolmogorov (vnk@cs.cornell.edu), 2003. */

/*
	This software implements an energy minimization technique described in

	What Energy Functions can be Minimized via Graph Cuts?
	Vladimir Kolmogorov and Ramin Zabih. 
	To appear in IEEE Transactions on Pattern Analysis and Machine Intelligence (PAMI). 
	Earlier version appeared in European Conference on Computer Vision (ECCV), May 2002. 

	More specifically, it computes the global minimum of a function E of binary
	variables x_1, ..., x_n which can be written as a sum of terms involving
	at most three variables at a time:

		E(x_1, ..., x_n) = \sum_{i}     E^{i}    (x_i)
		                 + \sum_{i,j}   E^{i,j}  (x_i, x_j)
		                 + \sum_{i,j,k} E^{i,j,k}(x_i, x_j, x_k)

	The method works only if each term is "regular". Definitions of regularity
	for terms E^{i}, E^{i,j}, E^{i,j,k} are given below as comments to functions
	add_term1(), add_term2(), add_term3(). 

	This software can be used only for research purposes. IF YOU USE THIS SOFTWARE,
	YOU SHOULD CITE THE AFOREMENTIONED PAPER IN ANY RESULTING PUBLICATION.

	In order to use it, you will also need a MAXFLOW software which can be
	obtained from http://www.cs.cornell.edu/People/vnk/software.html


	Example usage
	(Minimizes the following function of 3 binary variables:
	E(x, y, z) = x - 2*y + 3*(1-z) - 4*x*y + 5*|y-z|):

	///////////////////////////////////////////////////

	#include <stdio.h>
	#include "energy.h"

	void test_energy()
	{
		// Minimize the following function of 3 binary variables:
		// E(x, y, z) = x - 2*y + 3*(1-z) - 4*x*y + 5*|y-z|
		   
		Energy::Var varx, vary, varz;
		Energy *e = new Energy();

		varx = e -> add_variable();
		vary = e -> add_variable();
		varz = e -> add_variable();

		e -> add_term1(varx, 0, 1);  // add term x ,常数项为0,一次项系数为1
		e -> add_term1(vary, 0, -2); // add term -2*y
		e -> add_term1(varz, 3, 0);  // add term 3*(1-z)

		//e -> add_term2(x, y, 0, 0, 0, -4); // add term -4*x*y
		//e -> add_term2(y, z, 0, 5, 5, 0); // add term 5*|y-z|

		Energy::TotalValue Emin = e -> minimize();
		
		printf("Minimum = %d\n", Emin);
		printf("Optimal solution:\n");
		printf("x = %d\n", e->get_var(varx));
		printf("y = %d\n", e->get_var(vary));
		printf("z = %d\n", e->get_var(varz));

		delete e;
	}

	///////////////////////////////////////////////////
*/

输出结果:

boykov跟kolmogorkov与2001年提出的一种新的最大流最小割算法,该算法基于增广路算法,通过扩展,标记,更新被标记的节点,形成新的搜索树,并不断重复。

标准移动的定义:在进行能量函数的最优化过程中,仅改变图像中一个像素点的视差标记值,如图 4-2(b)示。通过这种标准移动很容易遇到局部极小值,从而不能准确的计算出能量函数的最小值。而α 扩展移动则是对那些视差标记不为α 的集合同时进行大规模的优化(多个像素同时进行标准移动),使其中的一部分像素点的视差标记重新被标记为α ,剩余的像素点集合的视差标记值保持不变,如图 4-2(c)示,视差标记为β 和γ 中的部分像素点被重新标记为α 。而α − β交换移动则是在一次交换移动(可以理解为优化)的过程中,视差标记α 像素点集合和视差标记为β 的像素点集合同时大规模进行交换(swap),而那些视差标记不等于α 和β 的像素点集合则不改变,如图 4-2(d)示,标记为γ 的像素集合没有发生改变,视差标记α 像素点集合和视差标记为β 进行了部分交换。

图像分割论文合集下载:

http://download.csdn.net/detail/wangyaninglm/8292305

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2014年11月01日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档