利用最大流最小割算法matlab割图

2023-05-16

目录

练习思路

matlab绘图

 噪音

坐标编码

邻接矩阵

最大流最小割算法

对最大流最小割算法求解结果转换为图像

源代码:

运行实例:

TIPS:


最近学习了最大流和最小割算法,可以把图看成是一些点的集合,色彩差值的倒数看做是权重,可以利用最小割实现简单的graph-cut操作。现在做个简单的分割椭圆的割图练习。

练习思路

先用matlab的矩形色彩绘图工具绘制出椭圆的图形,再添加随机噪音,使椭圆不太明显,接着将色块的坐标编码为一维数字,然后做出邻接矩阵,用matlab的最大流最小割函数求最大流,将分割出的数字解编码为坐标,重新赋值颜色,完成graph-cut操作。

matlab绘图

matlab绘制矩阵色块有两种方法:

1.pcolor函数,pcolor(X,Y,C),X为横坐标,Y为纵坐标,C为色值矩阵;

pcolor函数绘图时,色值对应的矩阵块是1-2,2-3之间的,所以C可显示范围要少一行一列。

要对应起来的话,可以换成X和Y可以换成0.5开始。如下:

pcolor有方格,而且横坐标是从左向右排列的,纵坐标从下到上排列的。不过本次没有用pcolor用的是imagesc。

2.imagesc(G)。G为色值矩阵。这个和pcolor不一样,色值和坐标是一一对应的。

G(y , x)y行数,对应图像的纵坐标,x列数,对应图像的横坐标。

imagesc没有方格,纵坐标是从上到下排列的。

 噪音

对于正常图片可以用rgb2grey做成灰度图,然后用randn生成高斯噪音。

对于本次练习,也可以用randn做正态分布随机数,不过本次练习采用了rand采取随机数。

坐标编码

色块的坐标是二维的(a , b),但是需要简化成一个数字,因为我设置的坐标最大值为M,所以采用n = M * (x - 1) + x + y来编码。对于一个x来说,当前x下的这一组数上限是M*(x + 1),下一组的数下限是(M + 1)*x + 2,刚好可以分隔开。所以,每一个色块有一个独一无二的n作为它的新坐标,用新坐标来做邻接矩阵。

邻接矩阵

邻接矩阵可以做成有向图和无向图两种,还有正常矩阵和稀疏矩阵两种。无向图需要是对称矩阵。

本次练习是做的无向图。权重是用坐标上限M的任意次幂除去色值差值的平方,放大权重。

最大流最小割算法

最大流最小割是网络流的重要模型,在一个网络流的图中,设置一个源点和汇点,网络流图中的最大流,即能够运输得到最大流量和最小割,即将图中的点分为两拨,两拨之间连线权重最小的和,问题等价。

matlab计算最大流最小割有两个算法:graphmaxflow和maxflow,两者输出的数值略有差别,输入上,graphmaxflow需要输入无向图的稀疏矩阵,maxflow需要输入有向图。本次练习用的是后者。

对最大流最小割算法求解结果转换为图像

将最大流算法求出的最小割所分出来的区域,将有源点的区域的点转换为坐标,作图。

源代码:

imagesc.m

%用imagesc绘制椭圆
function[map,paint] = imagesc_ellipse(M,a,b)
map = zeros(M);
for x = 1:M
    for y = 1:M
        if (((x-round(M/2))^2*b^2 + (y-round(M/2))^2*a^2) <= a^2*b^2)
            map(y , x) = 100;
        end
    end
end
paint = imagesc(map);

imagesc_encode.m

%图矩阵编码列表
function[point_list,centre_code] = imagesc_encode(M)
point_list = 1:M^2;
t = 0;
for x = 1 : M
    for y = 1 : M
        n = M * (x - 1) + x + y;
        t = t + 1;
        point_list(t) = n;
    end
end
%中心编码
centre_code = find(point_list == M * round(M/2));

imagesc_unencode_matrix.m

%制作邻接矩阵
function[matrix] = imagesc_unencode_matrix(M,map,point_list)
matrix = zeros(M^2);m = 50;
for i = 1:M^2
    x = ceil(point_list(i)/(M+1));
    y = point_list(i) - M*(x-1)-x;
    %与下面的点建立联系
    if(y~=M)
        yy = y + 1;
        n = M * (x - 1) + x + yy;
        n = find(point_list == n);
        store = (map(y,x)-map(yy,x))^2;
        matrix(n,i)=round(M^m/store);
        matrix(i,n)=round(M^m/store);
    end
    %与右边的点建立联系
    if(x~=M)
        xx = x + 1;
        n = M * (xx - 1) + xx + y;
        n = find(point_list == n);
        store = (map(y,x)-map(y,xx))^2;
        matrix(n,i)=round(M^m/store);
        matrix(i,n)=round(M^m/store);
    end
    %给边点建立强联系
    if(x == 1||x == M||y == 1||y == M)
       matrix(M^2,i) = inf;
       matrix(i,M^2) = inf; 
    end
end

imagesc_Result_processing.m

%最后割图结果处理
function[result] = imagesc_Result_processing(map,cs,point_list,M)
MAP =map;
for i = 1:length(cs)
    cs(i) = point_list(cs(i));
   x = ceil(cs(i)/(M+1));
   y = cs(i) - M*(x-1)-x;
   MAP(y,x) = 100;
end
figure;
result = imagesc(MAP);

gtsf6.m(主程序)

%最大流最小割图割算法
clear;clc;close all;
%绘制椭圆啦
M = 20;A = 7;B = 4;
[map,] = imagesc_ellipse(M,A,B);
%加点点噪声
map = abs(map - rand(M)*40);
piant = imagesc(map);
%编码变成列表
[point_list,centre_code] = imagesc_encode(M);
%绘制邻接矩阵
matrix = imagesc_unencode_matrix(M,map,point_list);
%绘制有权有向图
paint = digraph(matrix);
%最大流最小割
[~,~,cs,] = maxflow(paint, centre_code, M^2);
%最后结果处理
result = imagesc_Result_processing(map,cs,point_list,M);

运行实例:

原图像

graph-cut图像

TIPS:

1.在gtsf6.m的第四行是椭圆的形状大小参数;
2.在gtsf6.m的第七行rand(M)后面的常数是调整噪声的参数,40已经很高了,勉强可以分辨出来椭圆;
3.imagesc_unencode_matrix.m的第三行m是M的阶数,50可以满足7*7-40*40的图像,噪音参数是40时,结果不稳定,小噪音下结果稳定。
4.可以通过调整样本矩和噪音的参数,得到不同图像下稳定的结果。
5.当图像是90*90时,噪音参数为40,M阶数为1,成功割图几率较大。

写的不是很详细啦。不过还是希望各位看官看的满意。瑞斯拜~~~

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

利用最大流最小割算法matlab割图 的相关文章

  • redis的安装以及漏洞学习

    redis的安装以及漏洞学习 redis的安装redis的基本命令redis的一些漏洞redis未授权redis写入文件redis计划任务反弹shell写ssh公钥登录redis主从以上提到的这些漏洞 xff0c 都是基于未授权访问 red
  • python批量检测域名和url能否打开

    python批量检测域名和url能否打开 python批量检测域名和url能否打开批量在浏览器中打开url或者域名总结 最近在挖src xff0c 然后有大量的域名 xff0c 而且大部分打不开 xff0c 所以就很浪费时间 xff0c 写
  • Failed to restart network.service: Unit network.service not found.

    解决 Failed to restart network service Unit network service not found 输入命令时遇到了问题 span class token function service span ne
  • nginx的启动,停止

    nginx的启动 xff0c 停止 启动启动代码格式 nginx的停止有三种方式 xff1a 从容停止快速停止强制停止 验证nginx配置文件是否正确方法一 xff1a 进入nginx安装目录sbin下 xff0c 输入命令 nginx t
  • 虚拟机连不上网解决办法,以及出现Ubuntu connect: Network is unreachable

    虚拟机连不上网解决办法 xff0c 以及出现Ubuntu connect Network is unreachable 问题来源具体过程 问题来源 出现了Ubuntu connect Network is unreachable这个问题 x
  • linux持久化

    linux持久化后门 添加超级用户SUID shellalias 后门inetdcrontab后门ssh公钥免密ssh软连接SSH wrapper后门PAM隐身登录隐藏文件Git hooksPROMPT COMMAND后门PROMPT CO
  • linux恶意进程隐藏

    https mp weixin qq com s 6Z4tErcnusYHTqiSUSVz3A https blog csdn net nzjdsds article details 82919100
  • 图图图图图

  • windows提权总结

    windows提权总结 内核溢出提权Windows系统配置错误提权系统服务权限配置错误注册表键AlwaysInstallElevated可信任服务路径漏洞自动安装配置文件计划任务 Windows组策略首选项提权 SYSVOL GPP SYS
  • 运行Intel realsense L515相机

    运行Intel realsense L515相机 首先去官 https www intelrealsense com sdk 2 xff0c 按照上面的提示安装各种文件 xff0c 然后输入realsense viewer出现可视化窗口 下
  • python的shellcode_loader解释

    python的shellcode loader解释 代码 loader传到主机执行 xff0c shellcode传到自己的服务器上 简单的python shellcode加载器 xff0c 直接上代码 xff0c 注释都在代码里 代码 s
  • 「网络工程师必会技能」-路由器介绍和路由器基本配置

    网络工程师必会技能 路由器介绍和路由器基本配置 xff0c 这是每个网络必须会的技能 xff0c 不是你有证书就一个网络工程师了哦 xff01 以Cisco路由器为例说明 xff1a xff08 1 xff09 访问路由器 访问路由器与访问
  • 英飞凌微控制器,驱动物联网的关键“大脑”

    英飞凌微控制器 xff0c 驱动物联网的关键 大脑 英飞凌各种各样的传感器以及基于它们的创新应用 xff0c 可谓是打开了传感器的 兵器库 xff0c 令人大开眼界 今天 xff0c 我们将进入 计算 这一环节 xff0c 看看唯样商城代理
  • EMC对策产品:TDK扩大了内置ESD保护功能的陷波滤波器阵容

    EMC对策产品 xff1a TDK扩大了内置ESD保护功能的陷波滤波器阵容 新的陷波滤波器同时实现了ESD保护和最大频率为5 3 GHz频段噪声抑制抑制无线通信中产生的TDMA噪声 xff0c 提高无线信号接收灵敏度强大的静电保护能力 xf
  • 这27个电源符号,别再分不清 快收藏起来学习

    这27个电源符号 xff0c 别再分不清 xff01 快收藏起来学习 以下的V代表Volatge的意思 电源符号 解析 VCC C可以理解为三极管的集电极Collector或者电路Circuit xff0c 指电源正极 VDD D可以理解为
  • 74ls160引脚图引脚图和功能真值表

    74ls160引脚图管脚图及功能真值表 xff0c 74ls160引脚图管脚图74LS160的功能真值表 综合电路图 74ls160引脚图管脚图 74LS160的功能真值表 唯样商城是本土元器件目录分销商 xff0c 采用 小批量 现货 样
  • 最全74HC04六反相器中文资料|引脚图及功能表|应用电路图

    最全74HC04六反相器中文资料 引脚图及功能表 应用电路图 最全74HC04六反相器中文资料 引脚图及功能表 应用电路图 xff0c 该74HC04 74HCT04是高速CMOS器件 xff0c 低功耗肖特基的TTL LSTTL 电路 功
  • 房卡一插就有电 酒店插卡取电原理解析

    房卡一插就有电 酒店插卡取电原理解析 酒店插卡取电的原理是什么 xff0c 入住酒店只需用房卡一插就有电 xff0c 原理是什么呢 xff1f 只是一张塑料片不能导电的啊 导读 xff1a 酒店插卡取电的原理是什么 xff0c 入住酒店只需
  • SiC MOSFET驱动电压的分析及探讨

    SiC设计干货分享 xff08 一 xff09 xff1a SiC MOSFET驱动电压的分析及探讨 随着制备技术的进步 xff0c 在需求的不断拉动下 xff0c 碳化硅 xff08 SiC xff09 器件与模块的成本逐年降低 相关产品
  • EM-500储能网关的AI采集性能实测

    EM 500储能网关的AI采集性能实测 EM 500是致远电子面向工商储能应用推出的高性价比储能网关产品 为满足采集外部传感器数据需要 xff0c EM 500设计内置了多通道高性能AI采集接口 xff0c 本文将对其进行一次实测 EM 5

随机推荐

  • 【IoT开发】UART通信高频测试

    测试所使用芯片 STM32F103RCT6 UART收发的极限频率 xff1a bytes s 1 发送频率 主程序循环发送一字节u8整型 xff0c 记录次数 while 1 t 43 43 if t 61 61 255 t 61 0 p
  • 560V输入、无光隔离反激式转换器

    560V输入 无光隔离反激式转换器 在传统的隔离式高压反激式转换器中 xff0c 使用光耦合器将稳压信息从副边基准电压源电路传输到初级侧 xff0c 从而实现严格的稳压 问题在于 xff0c 光耦合器大大增加了隔离设计的复杂性 xff1a
  • 用于DC-DC转换器的MIL-SPEC COTS EMC输入滤波器

    用于DC DC转换器的MIL SPEC COTS EMC输入滤波器 DC DC转换器的开关动作可能会引起不良的共模和差模噪声 xff0c 在频谱的许多点上创建不可接受的干扰 前端 xff08 或电力线 xff09 滤波器旨在在DC DC转换
  • C语言中调用nop();解决办法

    C语言中调用 nop 解决办法 可在头文件中添加 include lt intrins h gt 或是直接删去 nop intrins h一般用在keilC51单片机编程中 xff0c 一般程序中需要使用到空指令 nop 字符循环移位指令
  • rosrun teleop_twist_keyboard teleop_twist_keyboard.py

    rospack Error package teleop twist keyboard not found 解决方案 xff1a 1 cd catkin ws src xff08 如果没有这个目录先在工作目录下创建工作空间 xff1a mk
  • ubuntu20.04安装ros配置秘钥时出现gpg: keyserver receive failed: Connection timed out

    gpg keyserver receive failed Connection timed out也是从公钥服务器接收失败 xff1a 连接超时 解决方案1 换自己的手机热点 解决方案2 切换网络配置 xff1a 这大多数是网络的问题 xf
  • rosbag的命令使用以及代码编写

    概念 xff1a rosbag是用于录制和回放 ROS 主题的一个工具集 作用 实现了数据的复用 xff0c 方便调试 测试 本质 xff1a rosbag本质也是ros的节点 xff0c 当录制时 xff0c rosbag是一个订阅节点
  • 格式化串漏洞

    格式化字符串漏洞本身并不算缓冲区溢出漏洞 xff0c 这里作为比较典型的一类漏洞进行简单介绍 为了能够将字符串 变量 地址等数据按照指定格式输出 xff0c 通常使用包含格式化控制符的常量字符串作为格式化串 xff0c 然后指定用相应变量来
  • 单链表的遍历

    1 什么是遍历 遍历就是把单链表的各个节点挨个拿出来 xff0c 一个不能少 xff0c 也不能重复 xff0c 追求效率 2 如何遍历单链表 xff08 1 xff09 分析数据结构的本身特点 xff0c 然后根据根据它本身的特点制定相应
  • 单链表之删除节点

    1 删除节点的步骤 xff08 1 xff09 找到要删除的这个节点 xff1a 通过遍历来查找节点 xff0c 从头指针 43 头节点开始 xff0c 顺着链表依次将各个节点拿出来 xff0c 按照一定的方法比对 xff0c 找到我们要删
  • lssek函数的用法及作用

    1 lseek函数的介绍 xff08 1 xff09 文件指针 xff1a 当我们对一个文件读写时 xff0c 一定需要打开这个文件 xff0c 所以我们操作的都是动态文件 xff0c 动态文件在内存中的形态就是流的形式 xff08 2 x
  • ubuntu20.04安装arduino IDE(亲测可用)

    步骤一 xff1a 在官网下载arduino安装包选择相应的版本 下载链接 步骤二 xff1a 解压下载的安装包在相应的目录下执行下面语句 tar xvf 安装包名 步骤三 xff1a 将解压后的安装包移动到 opt目录下 sudo mv
  • px4无人机常识介绍(固件,px4等)

    专业名词解释 aircraft 任何可以飞或者可以携带物品还是搭载旅客的飞行器统称为飞机 航空器 uav 无人驾驶飞机 vehicle 飞行器 airplane plane aero plane 有机翼和一个或多个引擎的飞行器统称为飞机 D
  • 在运行ros的Python文件时报找不到路径

    1 第一行解释器声明 xff0c 可以使用绝对路径定位到 python3 的安装路径 usr bin python3 xff0c 但是不建议 2 建议使用 usr bin env python 但是会抛出异常 usr bin env pyt
  • ros文件架构

    WorkSpace span class token operator span span class token operator span 自定义的工作空间 span class token operator span span cla
  • 用C语言和汇编给寄存器赋值

    1 用汇编 要根据目标CPU的体系 xff0c 用对应的汇编类型编写 ldr r0 61 0X020C4068 CCGR0 ldr r1 61 0XFFFFFFFF str r1 r0 2 用C语言 要知道相关寄存器地址 官方会提供参考手册
  • 商人过河--广度优先搜索--matlab实现

    进行了代码优化 目录 应用背景 xff1a 模型求解 xff1a 模型建立 xff1a 模型实现 xff1a 源代码 xff1a 运行结果 xff1a 附 xff1a 应用背景 xff1a M个商人与N个仆从过河 xff0c 小船一次可载k
  • C++---全局对象、局部对象、静态对象

    1 全局对象 xff0c 程序一开始 xff0c 其构造函数就先被执行 xff08 比程序进入点更早 xff09 xff1b 程序即将结束前其析构函数将被执行 2 局部对象 xff0c 当对象生成时 xff0c 其构造函数被执行 xff1b
  • 2011年B题交通巡警第一问的练习与实现

    题目要求 xff1a 试就某市设置交巡警服务平台的相关情况 xff0c 建立数学模型分析研究下面的问题 xff1a xff08 1 xff09 附件1中的附图1给出了该市中心城区A的交通网络和现有的20个交巡警服务平台的设置情况示意图 xf
  • 利用最大流最小割算法matlab割图

    目录 练习思路 matlab绘图 噪音 坐标编码 邻接矩阵 最大流最小割算法 对最大流最小割算法求解结果转换为图像 源代码 运行实例 TIPS 最近学习了最大流和最小割算法 xff0c 可以把图看成是一些点的集合 xff0c 色彩差值的倒数