python 实现从高分辨图像上抠取图像块


Posted in Python onJanuary 02, 2020

我就废话不多说了,直接上代码吧!

#coding=utf-8
import cv2
import numpy as np
import os
# 程序实现功能:
# 根据patch在高分辨率图像上的索引值,crop出对应区域的图像
# 并验证程序的正确性
'''
对于当前输入的3328*3328的高分辨率特征图,首先resize到640*640
然后根据当前的patch文件名(包含了patch在高分辨率图像上的行索引和列索引)
这个索引值是将高分辨率图像划分成多个没有overlap的256*256的图像块之后的行索引和列索引
行索引range(1,11),列索引range(0,12)
3328=13*256
'''

index='IDRiD_03_3_12.jpg'
raw_img_path='F:\\2\\eye_seg_con\\eye_seg\\joint_data\\raw_image\\train'
patches_path='F:\\2\\eye_seg_con\\eye_seg\\joint_data\\patches\\train'
true_patches=cv2.imread(os.path.join(patches_path,index))[:,:,::-1]

print(os.path.join(raw_img_path,index.split('_')[0]+index.split('_')[1]+'.jpg'))

hr_img=cv2.imread(os.path.join(raw_img_path,index.split('_')[0]+'_'+index.split('_')[1]+'.jpg'))[:,:,::-1]
hr_img=cv2.resize(hr_img,(640,640))# hr_img RGB

'''
640/13=49.23076923076923 记作unit
将640*640的区域平均划分成13*13份,每一份的像素点大小是unit*unit
然后将对应位置(取整)的图像块抠出来,resize成256*256大小
'''
unit=640/13
patch_row_num = int(index[:-4].split('_')[2])
patch_col_num = int(index[:-4].split('_')[3])

row_start=round(patch_row_num*unit)
row_end=round((patch_row_num+1)*unit)
col_start=round(patch_col_num*unit)
col_end=round((patch_col_num+1)*unit)

my_patch=hr_img[row_start:row_end,col_start:col_end,:]
my_patch=cv2.resize(my_patch,(256,256))
my_patch=np.array(my_patch,dtype=np.uint8)

cv2.imshow('true_patches',true_patches[:,:,::-1])
cv2.waitKey(0)

cv2.imshow('my_patch',my_patch[:,:,::-1])
cv2.waitKey(0)

# # hr_img RGB
#
# # cv2.imshow('1',hr_img[:,:,::-1])
# # cv2.waitKey(0)
#
# hr_img2=cv2.imread(os.path.join(raw_img_path,index.split('_')[0]+'_'+index.split('_')[1]+'.jpg'))
# hr_img2=cv2.resize(hr_img2,(640,640))[:,:,::-1]# hr_img2 RGB
# # cv2.imshow('2',hr_img2[:,:,::-1])
# # cv2.waitKey(0)
#
# print(np.sum(hr_img2-hr_img))# 0

# 结论:
# 对于cv2.resize函数而言,无论是先进行BGR的通道转换,再resize,还是先进行resize,再进行BGR通道转换
# 所得到的图像是相同的,即resize和通道维度的变换可交换顺序
# 实际上resize只发生在spatial dimension,而通道变换发生在channels dimension,所以空间维度上的插值变换
# 是在每个通道维度上独立进行的。
# 另外,对于计算机而言,所读取到的彩色图像就是H*W*3的矩阵而已,它本身是没有办法区分究竟是BGR格式还是RGB格式的

以上这篇python 实现从高分辨图像上抠取图像块就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
举例讲解Python中装饰器的用法
Apr 27 Python
动感网页相册 python编写简单文件夹内图片浏览工具
Aug 17 Python
通过pycharm使用git的步骤(图文详解)
Jun 13 Python
python自动化测试之如何解析excel文件
Jun 27 Python
Python 使用list和tuple+条件判断详解
Jul 30 Python
Python 余弦相似度与皮尔逊相关系数 计算实例
Dec 23 Python
关于初始种子自动选取的区域生长实例(python+opencv)
Jan 16 Python
基于python修改srt字幕的时间轴
Feb 03 Python
利用jupyter网页版本进行python函数查询方式
Apr 14 Python
详解Python中namedtuple的使用
Apr 27 Python
python中温度单位转换的实例方法
Dec 27 Python
Python Django项目和应用的创建详解
Nov 27 Python
python base64库给用户名或密码加密的流程
Jan 02 #Python
python文件处理fileinput使用方法详解
Jan 02 #Python
linux 下python多线程递归复制文件夹及文件夹中的文件
Jan 02 #Python
Pytorch的mean和std调查实例
Jan 02 #Python
pytorch 图像预处理之减去均值,除以方差的实例
Jan 02 #Python
Linux下升级安装python3.8并配置pip及yum的教程
Jan 02 #Python
pytorch实现focal loss的两种方式小结
Jan 02 #Python
You might like
分享8个最佳的代码片段在线测试网站
2013/06/29 PHP
ThinkPHP视图查询详解
2014/06/30 PHP
微信公众平台开发教程⑤ 微信扫码支付模式介绍
2019/04/10 PHP
使用prototype.js进行异步操作
2007/02/07 Javascript
JS获得URL超链接的参数值实例代码
2013/06/21 Javascript
javascript实现iframe框架延时加载的方法
2014/10/30 Javascript
JavaScript知识点总结(十六)之Javascript闭包(Closure)代码详解
2016/05/31 Javascript
JS实现漂亮的时间选择框效果
2016/08/20 Javascript
jQuery基于xml格式数据实现模糊查询及分页功能的方法
2016/12/25 Javascript
基于Vue实现页面切换左右滑动效果
2020/06/29 Javascript
jQuery 1.9版本以上的浏览器判断方法代码分享
2017/08/28 jQuery
十个免费的web前端开发工具详细整理
2017/09/18 Javascript
vue项目添加多页面配置的步骤详解
2019/05/22 Javascript
微信小程序使用字体图标的方法
2019/05/23 Javascript
微信小程序wx.navigateTo中events属性实现页面间通信传值,数据同步
2019/07/13 Javascript
js如何验证密码强度
2020/03/18 Javascript
[03:55]2016国际邀请赛中国区预选赛首日TOP10精彩集锦
2016/06/27 DOTA
动态创建类实例代码
2009/10/07 Python
python下paramiko模块实现ssh连接登录Linux服务器
2015/06/03 Python
python使用pandas实现数据分割实例代码
2018/01/25 Python
python pandas消除空值和空格以及 Nan数据替换方法
2018/10/30 Python
Python 脚本获取ES 存储容量的实例
2018/12/27 Python
对python多线程中互斥锁Threading.Lock的简单应用详解
2019/01/11 Python
详解pandas的外部数据导入与常用方法
2019/05/01 Python
python实现桌面气泡提示功能
2019/07/29 Python
python实现最短路径的实例方法
2020/07/19 Python
Pycharm学生免费专业版安装教程的方法步骤
2020/09/24 Python
全球高级音频和视频专家:HiDef Lifestyle
2019/08/02 全球购物
优秀中专生推荐信
2013/11/17 职场文书
家长对孩子的评语
2014/04/18 职场文书
法人代表授权委托书范文
2014/09/10 职场文书
工厂员工辞职信范文
2015/05/12 职场文书
《检阅》教学反思
2016/02/22 职场文书
十大动画制作软件,Adobe产品上榜两款,第一是行业标准软件
2022/03/18 杂记
JavaScript实现两个数组的交集
2022/03/25 Javascript
Python matplotlib多个子图绘制整合
2022/04/13 Python