Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
PaddlePaddle
PaddleSeg
提交
ef1f2e2b
P
PaddleSeg
项目概览
PaddlePaddle
/
PaddleSeg
通知
286
Star
8
Fork
1
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
53
列表
看板
标记
里程碑
合并请求
3
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
PaddleSeg
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
53
Issue
53
列表
看板
标记
里程碑
合并请求
3
合并请求
3
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
ef1f2e2b
编写于
9月 10, 2019
作者:
L
LutaoChu
提交者:
GitHub
9月 10, 2019
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Create labelme2seg.md
上级
fceb5815
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
95 addition
and
0 deletion
+95
-0
docs/annotation/labelme2seg.md
docs/annotation/labelme2seg.md
+95
-0
未找到文件。
docs/annotation/labelme2seg.md
0 → 100644
浏览文件 @
ef1f2e2b
# LabelMe数据标注教程
## 1 LabelMe的安装
用户在采集完用于训练、评估和预测的图片之后,需使用数据标注工具
[
LabelMe
](
https://github.com/wkentaro/labelme
)
完成数据标注。LabelMe支持在Windows/macOS/Linux三个系统上使用,且三个系统下的标注格式是一样。具体的安装流程请参见
[
官方安装指南
](
https://github.com/wkentaro/labelme
)
。
## 2 LabelMe的使用
打开终端输入
`labelme`
会出现LableMe的交互界面,可以先预览
`LabelMe`
给出的已标注好的图片,再开始标注自定义数据集。
<div
align=
"center"
>
<img
src=
"../imgs/annotation/image-1.png"
width=
"600px"
/>
<p>
图1 LableMe交互界面的示意图
</p>
</div>
*
预览已标注图片
获取
`LabelMe`
的源码:
```
git clone https://github.com/wkentaro/labelme
```
终端输入
`labelme`
会出现LableMe的交互界面,点击
`OpenDir`
打开
`<path/to/labelme>/examples/semantic_segmentation/data_annotated`
,其中
`<path/to/labelme>`
为克隆下来的
`labelme`
的路径,打开后示意的是语义分割的真值标注。
<div
align=
"center"
>
<img
src=
"../imgs/annotation/image-2.png"
width=
"600px"
/>
<p>
图2 已标注图片的示意图
</p>
</div>
*
开始标注
请按照下述步骤标注数据集:
(1) 点击
`OpenDir`
打开待标注图片所在目录,点击
`Create Polygons`
,沿着目标的边缘画多边形,完成后输入目标的类别。在标注过程中,如果某个点画错了,可以按撤销快捷键可撤销该点。Mac下的撤销快捷键为
`command+Z`
。
<div
align=
"center"
>
<img
src=
"../imgs/annotation/image-3.png"
width=
"600px"
/>
<p>
图3 标注单个目标的示意图
</p>
</div>
(2) 右击选择
`Edit Polygons`
可以整体移动多边形的位置,也可以移动某个点的位置;右击选择
`Edit Label`
可以修改每个目标的类别。请根据自己的需要执行这一步骤,若不需要修改,可跳过。
<div
align=
"center"
>
<img
src=
"../imgs/annotation/image-4-1.png"
width=
"00px"
/>
<img
src=
"../imgs/annotation/image-4-2.png"
width=
"600px"
/>
<p>
图4 修改标注的示意图
</p>
</div>
(3) 图片中所有目标的标注都完成后,点击
`Save`
保存json文件,
**请将json文件和图片放在同一个文件夹里**
,点击
`Next Image`
标注下一张图片。
LableMe产出的真值文件可参考我们给出的文件夹
`data_annotated`
。
<div
align=
"center"
>
<img
src=
"../imgs/annotation/image-5.png"
width=
"600px"
/>
<p>
图5 LableMe产出的真值文件的示意图
</p>
</div>
## 3 数据格式转换
*
我们用于完成语义分割的数据集目录结构如下:
```
my_dataset # 根目录
|-- JPEGImages # 数据集图片
|-- SegmentationClassPNG # 数据集真值
| |-- xxx.png # 像素级别的真值信息
| |...
|-- class_names.txt # 数据集的类别名称
```
<div
align=
"center"
>
<img
src=
"../imgs/annotation/image-6.png"
width=
"600px"
/>
<p>
图6 训练所需的数据集目录的结构示意图
</p>
</div>
*
运行转换脚本需要依赖labelme和pillow,如未安装,请先安装。Labelme的具体安装流程请参见
[
官方安装指南
](
https://github.com/wkentaro/labelme
)
。Pillow的安装:
```
shell
pip
install
pillow
```
*
运行以下代码,将标注后的数据转换成满足以上格式的数据集:
```
python labelme2seg.py <path/to/label_json_file> <path/to/output_dataset>
```
其中,
`<path/to/label_json_files>`
为图片以及LabelMe产出的json文件所在文件夹的目录,
`<path/to/output_dataset>`
为转换后的数据集所在文件夹的目录。
**需注意的是:`<path/to/output_dataset>`不用预先创建,脚本运行时会自动创建,否则会报错。**
转换得到的数据集可参考我们给出的文件夹
`my_dataset`
。其中,文件
`class_names.txt`
是数据集中所有标注类别的名称,包含背景类;文件夹
`JPEGImages`
保存的是数据集的图片;文件夹
`SegmentationClassPNG`
保存的是各图片的像素级别的真值信息,背景类
`_background_`
对应为0,其它目标类别从1开始递增,至多为255。
<div
align=
"center"
>
<img
src=
"../imgs/annotation/image-7.png"
width=
"600px"
/>
<p>
图7 训练所需的数据集各目录的内容示意图
</p>
</div>
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录