MSRA-TD500数据集坐标转换

2024-06-09 20:08
文章标签 数据 坐标 转换 msra td500

本文主要是介绍MSRA-TD500数据集坐标转换,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.根据MSRA-TD500原旋转坐标,转换成多边形坐标

import os
from math import *
import mathdef rotate(angle, x, y):"""基于原点的弧度旋转:param angle:   弧度:param x:       x:param y:       y:return:"""rotatex = math.cos(angle) * x - math.sin(angle) * yrotatey = math.cos(angle) * y + math.sin(angle) * xreturn rotatex, rotateydef xy_rorate(theta, x, y, centerx, centery):"""针对中心点进行旋转:param theta::param x::param y::param centerx::param centery::return:"""r_x, r_y = rotate(theta, x - centerx, y - centery)return centerx+r_x, centery+r_ydef rec_rotate(x, y, width, height, theta):"""传入矩形的x,y和宽度高度,弧度,转成QUAD格式:param x::param y::param width::param height::param theta::return:"""centerx = x + width / 2centery = y + height / 2x1, y1 = xy_rorate(theta, x, y, centerx, centery)x2, y2 = xy_rorate(theta, x+width, y, centerx, centery)x3, y3 = xy_rorate(theta, x, y+height, centerx, centery)x4, y4 = xy_rorate(theta, x+width, y+height, centerx, centery)return x1, y1,  x3, y3, x4, y4,x2, y2fname='IMG_0692.gt'
f=open(fname,'r')
savestr=''
for line in f:line=line.strip()line=line.split(' ')line=list(map(float,line))x,y=line[2],line[3]w,h=line[4],line[5]# centralx=x+w/2# centraly = y + h / 2points=[x,y,x,y+h,x+w,y+h,x+w,y]pointsrotate=rec_rotate(x,y,w,h,line[-1])savestr=savestr+str(int(pointsrotate[0]))+','+str(int(pointsrotate[1]))+','+str(int(pointsrotate[2]))+','+str(int(pointsrotate[3]))+','+str(int(pointsrotate[4]))+','+str(int(pointsrotate[5]))+','+str(int(pointsrotate[6]))+','+str(int(pointsrotate[7]))+','+'text\n'
savename=fname[0:-2]+'txt'
savef=open(savename,'w')
savef.write(savestr)
savef.close()

2.根据保存的txt坐标(逆时针8坐标)在原图上绘制多边形

from PIL import Image, ImageDrawim = Image.open("IMG_0692.jpg")
draw = ImageDraw.Draw(im)
fname='IMG_0692.txt'
f=open(fname,'r')
savestr=''
for line in f:line=line.strip()line=line.split(',')line=list(map(float,line[0:-1]))print(line)draw.polygon(line, outline='red')
im.show('t')

 

这篇关于MSRA-TD500数据集坐标转换的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1046171

相关文章

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

MyBatisPlus如何优化千万级数据的CRUD

《MyBatisPlus如何优化千万级数据的CRUD》最近负责的一个项目,数据库表量级破千万,每次执行CRUD都像走钢丝,稍有不慎就引起数据库报警,本文就结合这个项目的实战经验,聊聊MyBatisPl... 目录背景一、MyBATis Plus 简介二、千万级数据的挑战三、优化 CRUD 的关键策略1. 查

python实现对数据公钥加密与私钥解密

《python实现对数据公钥加密与私钥解密》这篇文章主要为大家详细介绍了如何使用python实现对数据公钥加密与私钥解密,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录公钥私钥的生成使用公钥加密使用私钥解密公钥私钥的生成这一部分,使用python生成公钥与私钥,然后保存在两个文

mysql中的数据目录用法及说明

《mysql中的数据目录用法及说明》:本文主要介绍mysql中的数据目录用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、版本3、数据目录4、总结1、背景安装mysql之后,在安装目录下会有一个data目录,我们创建的数据库、创建的表、插入的

Navicat数据表的数据添加,删除及使用sql完成数据的添加过程

《Navicat数据表的数据添加,删除及使用sql完成数据的添加过程》:本文主要介绍Navicat数据表的数据添加,删除及使用sql完成数据的添加过程,具有很好的参考价值,希望对大家有所帮助,如有... 目录Navicat数据表数据添加,删除及使用sql完成数据添加选中操作的表则出现如下界面,查看左下角从左

SpringBoot中4种数据水平分片策略

《SpringBoot中4种数据水平分片策略》数据水平分片作为一种水平扩展策略,通过将数据分散到多个物理节点上,有效解决了存储容量和性能瓶颈问题,下面小编就来和大家分享4种数据分片策略吧... 目录一、前言二、哈希分片2.1 原理2.2 SpringBoot实现2.3 优缺点分析2.4 适用场景三、范围分片

利用Python脚本实现批量将图片转换为WebP格式

《利用Python脚本实现批量将图片转换为WebP格式》Python语言的简洁语法和库支持使其成为图像处理的理想选择,本文将介绍如何利用Python实现批量将图片转换为WebP格式的脚本,WebP作为... 目录简介1. python在图像处理中的应用2. WebP格式的原理和优势2.1 WebP格式与传统

Redis分片集群、数据读写规则问题小结

《Redis分片集群、数据读写规则问题小结》本文介绍了Redis分片集群的原理,通过数据分片和哈希槽机制解决单机内存限制与写瓶颈问题,实现分布式存储和高并发处理,但存在通信开销大、维护复杂及对事务支持... 目录一、分片集群解android决的问题二、分片集群图解 分片集群特征如何解决的上述问题?(与哨兵模

浅析如何保证MySQL与Redis数据一致性

《浅析如何保证MySQL与Redis数据一致性》在互联网应用中,MySQL作为持久化存储引擎,Redis作为高性能缓存层,两者的组合能有效提升系统性能,下面我们来看看如何保证两者的数据一致性吧... 目录一、数据不一致性的根源1.1 典型不一致场景1.2 关键矛盾点二、一致性保障策略2.1 基础策略:更新数