当前位置: 首页 > news >正文

plt函数显示图片 在图片上画边界框 边界框坐标转换

一.读取图片并显示图片

%matplotlib inline
import torch
from d2l import torch as d2l
'''读取图片'''
image_path = '../data/images/cat_dog_new.jpg'
# 创建画板
figure = d2l.set_figsize()
image = d2l.plt.imread(image_path)
d2l.plt.imshow(image);

在这里插入图片描述

二.给出一个(x左上角,y左上角,x右下角,y右下角)类型的框,在图片上画出该框

'''边界框'''
box = (60,50,460,510)
def bbox_to_rect(bbox, color):# 将边界框(左上x,左上y,右下x,右下y)格式转换成matplotlib格式:# ((左上x,左上y),宽,高)return d2l.plt.Rectangle(xy=(bbox[0], bbox[1]), width=bbox[2]-bbox[0], height=bbox[3]-bbox[1],fill=False, edgecolor=color, linewidth=2)
# 返回一个画布,该画布上面有图画image
fig = d2l.plt.imshow(image)
# 在该画布上画一个矩形框
fig.axes.add_patch(bbox_to_rect(box,'red'));

在这里插入图片描述

三. 边界框坐标转换

3.1 左上角右下角格式的坐标 --> 边界框中心坐标,框的高和宽

原:(x1,y1,x2,y2)
w = x2-x1
h = y2-y1
中心坐标 = (x1+w/2,y1+h/2)

def box_corner_to_center(boxes):# 因为以后boxes可能不止一个,所以 boxes[:,0]取出所有行的第一列x1,y1,x2,y2 = boxes[:,0],boxes[:,1],boxes[:,2],boxes[:,3]w = x2-x1h = y2-y1x_center,y_center = x1 + w/2, y1 + h/2# axis=-1表示在最后一个维度上进行堆叠boxes = torch.stack((x_center,y_center,w,h),axis = -1)return boxes

创建两个左上角走下角格式的坐标boxes

dog_bbox, cat_bbox = [60.0, 45.0, 378.0, 516.0], [400.0, 112.0, 655.0, 493.0]
boxes = torch.tensor((dog_bbox,cat_bbox))
print(boxes)
boxes.shape
tensor([[ 60.,  45., 378., 516.],[400., 112., 655., 493.]])torch.Size([2, 4])

运行结果

box_corner_to_center(boxes)
tensor([[219.0000, 280.5000, 471.0000, 318.0000],[527.5000, 302.5000, 381.0000, 255.0000]])
torch.Size([2, 4])

3.2 边界框中心坐标,框的高和宽 --> 左上角右下角格式的坐标

原:(x_center,y_center,w,h)
x1 = x_center - 0.5w
y1 = y_center - 0.5
h
x2 = x_center + 0.5w
y2 = y_center + 0.5
h

def box_center_to_corner(boxes):x_center,y_center,w,h = boxes[:,0],boxes[:,1],boxes[:,2],boxes[:,3]x1,y1= x_center-0.5*w , y_center-0.5*hx2,y2= x_center+0.5*w , y_center+0.5*hboxes = torch.stack((x1,y1,x2,y2),axis=-1)return boxes
boxes = box_center_to_corner(boxes)
print(boxes)
boxes.shape
tensor([[ 60.,  45., 378., 516.],[400., 112., 655., 493.]])torch.Size([2, 4])
http://www.lryc.cn/news/163276.html

相关文章:

  • 运行期获得文件名和行号
  • 数组操作UNIAPP
  • MySQL——无法打开MySQL8.0软件安装包或者安装过程中失败,如何解决?
  • DB2存储过程如何编写和执行
  • SpringBoot + FFmpeg实现一个简单的M3U8切片转码系统
  • SpringCloud(35):Nacos 服务发现快速入门
  • OSPF实验:配置与检测全网互通
  • 常见的五种设计模式
  • pandas读取一个 文件夹下所有excel文件
  • Python网页请求超时如何解决
  • 虚幻引擎集成web前端<二>:UE4 像素流 与 web 通信
  • 618-基于FMC+的XCVU3P高性能 PCIe 载板 设计原理图
  • ABB UF C911B108 3BHE037864R010控制主板模块
  • 基于SpringBoot开发的疫情信息管理系统
  • 手敲Cocos简易地图编辑器:人生地图是一本不断修改的书,每一次编辑都是为了克服新的阻挡
  • MySQL——修改数据库和表的字符编码
  • 中国人民大学与加拿大女王大学金融硕士——人生总要逼自己一把
  • SAP MM学习笔记 - 错误 ME092 - Material mainly procured internally(原则上该物料只能内部调达)
  • 【EI会议征稿】2023年智能科学与计算机工程国际学术会议(ISCE 2023)
  • Java多线程编程
  • Windows wsl2安装Ubuntu
  • csp-j模拟赛1总结
  • 有哪些做流程图的软件?分享一些制作方法和注意事项
  • 人工智能AI 全栈体系(一)
  • 权限、认证与授权
  • JAVA 的四种访问权限
  • 【个人博客系统网站】注册与登录 · 加盐加密验密算法 · 上传头像
  • [H5动画制作系列] Sprite及Text Demo
  • 目标检测YOLO实战应用案例100讲-毫米波辐射图像去模糊重建与目标检测
  • Android10 SystemUI系列(一)概述