YOLO相同等级关键点标注修改方案
创作时间:
作者:
@小白创作中心
YOLO相同等级关键点标注修改方案
引用
CSDN
1.
https://m.blog.csdn.net/qq_43914400/article/details/138157163
在使用YOLOv8进行关键点检测时,如果需要标注大量相同等级的关键点,逐个标注会非常耗时。本文提出了一种解决方案:先统一标注这些关键点,再通过Python代码批量修改标签。这种方法可以显著提高标注效率,特别适用于处理像章鱼脚这样的相同等级关键点标注任务。
问题描述
在标注具有相同等级的关键点时,无法对每个点进行区分,且一个一个选标签会非常耗时。例如,人体的关键点都是不相同的:
而对于章鱼脚来说,各个脚的都是相同等级的关键点!如果想要进行区分标注十分困难,因此考虑统一标注相同的关键点,后续进行修改。
统一标注
首先,我们可以统一标注所有相同等级的关键点:
获取标注JSON文件
标注完成后,会生成一个包含所有关键点坐标的JSON文件,示例如下:
{
"version": "5.1.1",
"flags": {},
"shapes": [
{
"label": "foot",
"points": [
[
176.1094674556213,
45.95857988165682
]
],
"group_id": null,
"shape_type": "point",
"flags": {}
},
{
"label": "foot",
"points": [
[
335.28106508875743,
42.70414201183433
]
],
"group_id": null,
"shape_type": "point",
"flags": {}
},
{
"label": "foot",
"points": [
[
400.9615384615385,
216.66863905325448
]
],
"group_id": null,
"shape_type": "point",
"flags": {}
},
{
"label": "foot",
"points": [
[
264.2751479289941,
324.9526627218935
]
],
"group_id": null,
"shape_type": "point",
"flags": {}
},
{
"label": "foot",
"points": [
[
117.52958579881656,
208.97633136094677
]
],
"group_id": null,
"shape_type": "point",
"flags": {}
}
]
}
运行修改代码
接下来,我们使用Python代码批量修改这些关键点的标签:
import os
import json
# 载入JSON数据
def load_json(json_path):
with open(json_path, 'r') as file:
data = json.load(file)
return data
# 判断点是否在矩形框内
def is_point_in_rect(point, rect):
x_min = min(rect[0][0], rect[1][0])
x_max = max(rect[0][0], rect[1][0])
y_min = min(rect[0][1], rect[1][1])
y_max = max(rect[0][1], rect[1][1])
return x_min <= point[0] <= x_max and y_min <= point[1] <= y_max
# 处理JSON数据,寻找并重命名关键点
def process_data(data):
for shape in data['shapes']:
if shape['shape_type'] == 'rectangle':
# 找到矩形框
rect = shape['points']
# 寻找矩形内的所有关键点
seed_heads = [s for s in data['shapes'] if s['shape_type'] == 'point' and s['label'] == 'Seed_head' and is_point_in_rect(s['points'][0], rect)]
# 对关键点进行排序并重新命名
seed_heads.sort(key=lambda x: (x['points'][0][0], x['points'][0][1])) # 按x坐标和y坐标排序
for idx, head in enumerate(seed_heads):
head['label'] = f'foot{idx + 1}'
# 主函数
def main():
input_folder = 'keypoint' # 输入文件夹路径
output_folder = 'keypoint1' # 输出文件夹路径
# 确保输出文件夹存在,若不存在则创建
if not os.path.exists(output_folder):
os.makedirs(output_folder)
# 遍历输入文件夹中的所有文件
for filename in os.listdir(input_folder):
if filename.endswith('.json'):
json_path = os.path.join(input_folder, filename)
output_path = os.path.join(output_folder, filename)
data = load_json(json_path)
process_data(data)
# 保存修改后的数据
with open(output_path, 'w') as f:
json.dump(data, f, indent=4)
main()
需要修改的位置
在使用上述代码时,需要根据实际情况修改以下位置:
seed_heads = [s for s in data['shapes'] if s['shape_type'] == 'point' and s['label'] == 'foot' and is_point_in_rect(s['points'][0], rect)]
:将foot
修改成你的标签head['label'] = f'foot{idx + 1}'
:将foot
修改成你的标签input_folder = 'keypoint'
和output_folder = 'keypoint1'
:根据实际的文件夹路径进行修改
结果
下面是修改后的JSON文件:
{
"version": "5.1.1",
"flags": {},
"shapes": [
{
"label": "foot2",
"points": [
[
176.1094674556213,
45.95857988165682
]
],
"group_id": null,
"shape_type": "point",
"flags": {}
},
{
"label": "foot4",
"points": [
[
335.28106508875743,
42.70414201183433
]
],
"group_id": null,
"shape_type": "point",
"flags": {}
},
{
"label": "foot5",
"points": [
[
400.9615384615385,
216.66863905325448
]
],
"group_id": null,
"shape_type": "point",
"flags": {}
},
{
"label": "foot3",
"points": [
[
264.2751479289941,
324.9526627218935
]
],
"group_id": null,
"shape_type": "point",
"flags": {}
},
{
"label": "foot1",
"points": [
[
117.52958579881656,
208.97633136094677
]
],
"group_id": null,
"shape_type": "point",
"flags": {}
},
{
"label": "star",
"points": [
[
102.22868217054264,
30.984496124031068
],
[
414.63178294573646,
339.5116279069768
]
],
"group_id": null,
"shape_type": "rectangle",
"flags": {}
}
]
}
标签修改成功
总结
- 标注时可以选用相同名称进行标注节省时间
- 使用代码对JSON文件进行修改
- 找到框
- 找到所有点
- 判断哪个点在哪个框里后修改
- 完成标注关键点
热门推荐
供应链网络中物料流与信息流的联系
成人乙肝疫苗选哪一种
2025考研国家线公布:工学降13分创三年新低,文科单科线暗藏玄机
如何提高团队的公信力
房屋出租合同的签订流程是什么?
什么原因会让股票涨跌:影响股票价格涨跌的因素
胆碱酯酶高是怎么回事
胆碱酯酶高有什么危害
枸杞的功效与作用禁忌:哪些人不适合吃
作物控旺:平衡之道,丰收之匙!
为什么原创内容对SEO至关重要?
2025年中国液态奶市场深度分析:伊利、蒙牛龙头优势明显
“漏电的路灯杆”:暴雨季多地发生路人触电事故,该如何预防?
个人养老金制度将在全国范围内实施,开户人数突破7000万
筏板基础资料:概念、设计、施工与应用
女职工拒绝喝酒的自我保障与职场尊重
股票基本面分析包括哪些方面?
甘油容易被皮肤吸收吗
人类基因编辑技术的突破
学习编程时如何分配打代码和看理论的时间
线路避雷器绝缘值是多少?避雷器绝缘电阻要求
长安三万里的背景探析
肌少症自我檢測:4個簡單方法幫助評估肌肉健康狀態
维生素D与DHA同补:科学搭配,健康加倍
哪些行业、哪类人才火爆就业市场? 透过数据看春招市场新动向
如何系统分析奇门八字命盘
太空知识详解:从基本概念到未来展望
中医视角下的耳鸣:耳中韵律,非声自鸣
自学单片机如何做项目管理
哪个机构颁发安全生产考核合格证书?