README.md 6.4 KB
Newer Older
K
Kentaro Wada 已提交
1
<img src="https://github.com/wkentaro/labelme/blob/master/labelme/icons/icon.png?raw=true" align="right" />
K
Kentaro Wada 已提交
2

K
Kentaro Wada 已提交
3
# labelme: Image Polygonal Annotation with Python
K
Kentaro Wada 已提交
4

K
Kentaro Wada 已提交
5
[![PyPI Version](https://img.shields.io/pypi/v/labelme.svg)](https://pypi.python.org/pypi/labelme)
K
Kentaro Wada 已提交
6
[![Python Versions](https://img.shields.io/pypi/pyversions/labelme.svg)](https://pypi.org/project/labelme)
K
Kentaro Wada 已提交
7
[![Travis Build Status](https://travis-ci.org/wkentaro/labelme.svg?branch=master)](https://travis-ci.org/wkentaro/labelme)
K
Kentaro Wada 已提交
8
[![Docker Build Status](https://img.shields.io/docker/build/wkentaro/labelme.svg)](https://hub.docker.com/r/wkentaro/labelme)
K
Kentaro Wada 已提交
9 10


K
Kentaro Wada 已提交
11
Labelme is a graphical image annotation tool inspired by <http://labelme.csail.mit.edu>.  
12
It is written in Python and uses Qt for its graphical interface.
K
Kentaro Wada 已提交
13

K
Kentaro Wada 已提交
14
<img src="https://github.com/wkentaro/labelme/blob/master/examples/instance_segmentation/.readme/annotation.jpg?raw=true" width="80%" />  
K
Kentaro Wada 已提交
15
Fig 1. Example of annotations for instance segmentation.
K
Kentaro Wada 已提交
16

K
Kentaro Wada 已提交
17

18 19 20 21 22 23 24 25
## Features

- [x] Polygonal annotation
- [x] Predefined labels ([#76](https://github.com/wkentaro/labelme/pull/76))
- [x] Auto save mode ([#138](https://github.com/wkentaro/labelme/pull/138))
- [x] Support custom json keys ([#140](https://github.com/wkentaro/labelme/pull/140))
- [x] Undo by Ctrl-Z ([#112](https://github.com/wkentaro/labelme/pull/112), [#143](https://github.com/wkentaro/labelme/pull/143))
- [x] Customize by config file ([#144](https://github.com/wkentaro/labelme/pull/144))
K
Kentaro Wada 已提交
26
- [x] VOC dataset export ([semantic segmentation](https://github.com/wkentaro/labelme/blob/master/examples/semantic_segmentation), [instance segmentation](https://github.com/wkentaro/labelme/blob/master/examples/instance_segmentation))
27
- [x] Image level flag annotation ([#166](https://github.com/wkentaro/labelme/pull/166))
K
Kentaro Wada 已提交
28
- [x] Video annotation ([video annotation](https://github.com/wkentaro/labelme/blob/master/examples/video_annotation))
29 30


K
Kentaro Wada 已提交
31
## Requirements
K
Kentaro Wada 已提交
32

K
Kentaro Wada 已提交
33 34
- Ubuntu / macOS / Windows
- Python2 / Python3
K
Kentaro Wada 已提交
35
- [PyQt4 / PyQt5](http://www.riverbankcomputing.co.uk/software/pyqt/intro) / [PySide2](https://wiki.qt.io/PySide2_GettingStarted)
K
Kentaro Wada 已提交
36 37


K
Kentaro Wada 已提交
38
## Installation
K
Kentaro Wada 已提交
39

K
Kentaro Wada 已提交
40 41 42 43 44
There are options:

- Platform agonistic installation: Anaconda, Docker
- Platform specific installation: Ubuntu, macOS

K
Kentaro Wada 已提交
45
### Anaconda
K
Kentaro Wada 已提交
46 47 48 49

You need install [Anaconda](https://www.continuum.io/downloads), then run below:

```bash
K
Kentaro Wada 已提交
50
# python2
K
Kentaro Wada 已提交
51 52
conda create --name=labelme python=2.7
source activate labelme
K
Kentaro Wada 已提交
53
# conda install -c conda-forge pyside2
K
Kentaro Wada 已提交
54 55
conda install pyqt
pip install labelme
K
Kentaro Wada 已提交
56 57
# if you'd like to use the latest version. run below:
# pip install git+https://github.com/wkentaro/labelme.git
K
Kentaro Wada 已提交
58 59 60 61

# python3
conda create --name=labelme python=3.6
source activate labelme
K
Kentaro Wada 已提交
62
# conda install -c conda-forge pyside2
K
Kentaro Wada 已提交
63
# conda install pyqt
K
Kentaro Wada 已提交
64
pip install pyqt5  # pyqt5 can be installed via pip on python3
K
Kentaro Wada 已提交
65
pip install labelme
K
Kentaro Wada 已提交
66 67
```

K
Kentaro Wada 已提交
68
### Docker
K
Kentaro Wada 已提交
69

K
Kentaro Wada 已提交
70
You need install [docker](https://www.docker.com), then run below:
K
Kentaro Wada 已提交
71 72

```bash
K
Kentaro Wada 已提交
73
wget https://raw.githubusercontent.com/wkentaro/labelme/master/labelme/cli/on_docker.py -O labelme_on_docker
K
Kentaro Wada 已提交
74 75 76
chmod u+x labelme_on_docker

# Maybe you need http://sourabhbajaj.com/blog/2017/02/07/gui-applications-docker-mac/ on macOS
K
Kentaro Wada 已提交
77 78
./labelme_on_docker examples/tutorial/apc2016_obj3.jpg -O examples/tutorial/apc2016_obj3.json
./labelme_on_docker examples/semantic_segmentation/data_annotated
K
Kentaro Wada 已提交
79
```
K
Kentaro Wada 已提交
80

K
Kentaro Wada 已提交
81
### Ubuntu
K
Kentaro Wada 已提交
82 83

```bash
K
Kentaro Wada 已提交
84
# Ubuntu 14.04 / Ubuntu 16.04
K
Kentaro Wada 已提交
85
# Python2
86 87
# sudo apt-get install python-qt4  # PyQt4
sudo apt-get install python-pyqt5  # PyQt5
K
Kentaro Wada 已提交
88
sudo pip install labelme
K
Kentaro Wada 已提交
89
# Python3
90
sudo apt-get install python3-pyqt5  # PyQt5
K
Kentaro Wada 已提交
91
sudo pip3 install labelme
K
Kentaro Wada 已提交
92 93
```

K
Kentaro Wada 已提交
94
### macOS
K
Kentaro Wada 已提交
95 96

```bash
K
Kentaro Wada 已提交
97
# macOS Sierra
K
Kentaro Wada 已提交
98 99
brew install pyqt  # maybe pyqt5
pip install labelme  # both python2/3 should work
K
Kentaro Wada 已提交
100

K
Kentaro Wada 已提交
101 102
# or install standalone executable / app
brew install wkentaro/labelme/labelme
K
Kentaro Wada 已提交
103
brew cask install wkentaro/labelme/labelme
K
Kentaro Wada 已提交
104 105
```

K
Kentaro Wada 已提交
106

K
Kentaro Wada 已提交
107
## Usage
K
Kentaro Wada 已提交
108

K
Kentaro Wada 已提交
109 110
Run `labelme --help` for detail.  
The annotations are saved as a [JSON](http://www.json.org/) file.
K
Kentaro Wada 已提交
111 112

```bash
K
Kentaro Wada 已提交
113 114
labelme  # just open gui

K
Kentaro Wada 已提交
115 116
# tutorial (single image example)
cd examples/tutorial
K
Kentaro Wada 已提交
117 118 119 120 121 122 123 124 125 126
labelme apc2016_obj3.jpg  # specify image file
labelme apc2016_obj3.jpg -O apc2016_obj3.json  # close window after the save
labelme apc2016_obj3.jpg --nodata  # not include image data but relative image path in JSON file
labelme apc2016_obj3.jpg \
  --labels highland_6539_self_stick_notes,mead_index_cards,kong_air_dog_squeakair_tennis_ball  # specify label list

# semantic segmentation example
cd examples/semantic_segmentation
labelme data_annotated/  # Open directory to annotate all images in it
labelme data_annotated/ --labels labels.txt  # specify label list with a file
K
Kentaro Wada 已提交
127 128
```

K
Kentaro Wada 已提交
129
For more advanced usage, please refer to the examples:
K
Kentaro Wada 已提交
130

K
Kentaro Wada 已提交
131 132 133
* [Tutorial (Single Image Example)](https://github.com/wkentaro/labelme/blob/master/examples/tutorial)
* [Semantic Segmentation Example](https://github.com/wkentaro/labelme/blob/master/examples/semantic_segmentation)
* [Instance Segmentation Example](https://github.com/wkentaro/labelme/blob/master/examples/instance_segmentation)
K
Kentaro Wada 已提交
134
* [Video Annotation Example](https://github.com/wkentaro/labelme/blob/master/examples/video_annotation)
K
Kentaro Wada 已提交
135 136


K
Kentaro Wada 已提交
137 138
## FAQ

K
Kentaro Wada 已提交
139 140
- **How to convert JSON file to numpy array?** See [examples/tutorial](https://github.com/wkentaro/labelme/blob/master/examples/tutorial#convert-to-dataset).
- **How to load label PNG file?** See [examples/tutorial](https://github.com/wkentaro/labelme/blob/master/examples/tutorial#how-to-load-label-png-file).
K
Kentaro Wada 已提交
141 142
- **How to get annotations for semantic segmentation?** See [examples/semantic_segmentation](https://github.com/wkentaro/labelme/blob/master/examples/semantic_segmentation).
- **How to get annotations for instance segmentation?** See [examples/instance_segmentation](https://github.com/wkentaro/labelme/blob/master/examples/instance_segmentation).
K
Kentaro Wada 已提交
143 144


K
Kentaro Wada 已提交
145
## Screencast
K
Kentaro Wada 已提交
146

K
Kentaro Wada 已提交
147
<img src="https://github.com/wkentaro/labelme/blob/master/.readme/screencast.gif?raw=true" width="70%"/>
K
Kentaro Wada 已提交
148 149


K
Kentaro Wada 已提交
150
## Testing
K
Kentaro Wada 已提交
151 152 153 154 155 156 157 158

```bash
pip install hacking pytest pytest-qt
flake8 .
pytest -v tests
```


K
Kentaro Wada 已提交
159
## How to build standalone executable
K
Kentaro Wada 已提交
160

K
Kentaro Wada 已提交
161
Below shows how to build the standalone executable on macOS, Linux and Windows.  
K
Kentaro Wada 已提交
162
Also, there are pre-built executables in
K
Kentaro Wada 已提交
163
[the release section](https://github.com/wkentaro/labelme/releases).
K
Kentaro Wada 已提交
164 165

```bash
K
Kentaro Wada 已提交
166 167 168
# Setup conda
conda create --name labelme python=3.6
conda activate labelme
K
Kentaro Wada 已提交
169 170 171

# Build the standalone executable
pip install .
K
Kentaro Wada 已提交
172
pip install pyinstaller
K
Kentaro Wada 已提交
173
pyinstaller labelme.spec
K
Kentaro Wada 已提交
174
dist/labelme --version
K
Kentaro Wada 已提交
175 176 177
```


K
Kentaro Wada 已提交
178
## Acknowledgement
K
Kentaro Wada 已提交
179

K
Kentaro Wada 已提交
180 181
This repo is the fork of [mpitid/pylabelme](https://github.com/mpitid/pylabelme),
whose development has already stopped.