python 实现从高分辨图像上抠取图像块
2020-02-13 10:06
344 查看
我就废话不多说了,直接上代码吧!
#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使用CloudSight API实现简单的图像识别(image Recognition)
- 图像视频互转python 实现
- OpenCV之图像的读入、显示、保存——python/C++实现
- python识别图像并提取文字的实现方法
- OpenCV+Python实现图像运动模糊和高斯模糊
- python实现泊松图像融合
- python 实现双纵轴(y)轴图像的绘制(中文label),解决只显示一个折线label的问题
- Python3实现的旋转矩阵图像算法示例
- Python+OpenCV实现图像高斯模糊
- 通过AI平台使用python语音实现图像识别
- python实现的简单图像矩阵变换
- 图像处理DOG 算法,python结合cv2实现
- 【python下使用OpenCV实现计算机视觉读书笔记2】图像与字节的变换
- python实现画出e指数函数的图像
- Python数字图像处理之霍夫线变换实现详解
- python 实现对文件夹中的图像连续重命名
- Roberts、Sobel、Prewitt、Kirsch、Canny、Laplacian图像边缘检测原理及其代码实现(Python3)
- python实现能分辨优先级(+-*/)和括号的计算器
- Python实现PS图像调整之对比度调整功能示例
- [转]opencv3 图像处理 之 图像缩放( python与c++实现 )