Skip to content

Commit db43b49

Browse files
Rewrote README, added community projects and C++API doc
Signed-off-by: Gines Hidalgo <[email protected]>
1 parent fcc44e4 commit db43b49

27 files changed

+133
-98
lines changed

.github/issue_template.md

+2-2
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,6 @@
11
### Posting rules
22
1. **No duplicated posts, only 1 new post opened a day, and up to 2 opened a week**. Otherwise, extrict user bans will occur.
3-
- Check the [FAQ](https://github.com/CMU-Perceptual-Computing-Lab/openpose/blob/master/doc/4_faq.md) section, other GitHub issues, and general documentation before posting. E.g., **low-speed, out-of-memory, output format, 0-people detected, installation issues, ...**).
3+
- Check the [FAQ](https://github.com/CMU-Perceptual-Computing-Lab/openpose/blob/master/doc/05_faq.md) section, other GitHub issues, and general documentation before posting. E.g., **low-speed, out-of-memory, output format, 0-people detected, installation issues, ...**).
44
- Keep posting all your issues in the same post.
55
- No bans if you are unsure whether the post is duplicated!
66
2. **Fill all** the **Your System Configuration section** if you are facing an error or unexpected behavior. Some posts (e.g., feature requests) might not require it.
@@ -82,4 +82,4 @@ Select the topic(s) on your post, delete the rest:
8282
- Portable demo or compiled library?
8383

8484
10. If **speed performance** issue:
85-
- Report OpenPose timing speed based on [this link](https://github.com/CMU-Perceptual-Computing-Lab/openpose/blob/master/doc/5_maximizing_openpose_speed.md#profiling-speed).
85+
- Report OpenPose timing speed based on the [profiling documentation](https://github.com/CMU-Perceptual-Computing-Lab/openpose/blob/master/doc/06_maximizing_openpose_speed.md#profiling-speed).

.github/workflows/main.yml

+4-2
Original file line numberDiff line numberDiff line change
@@ -255,9 +255,9 @@ jobs:
255255
run: scripts/CI/run_tests.sh
256256

257257
- name: Docs APT packages
258-
# The Doxygen apt-get version for Ubuntu 20 is 1.8.17, which has some bugs fixed in 1.9.1
259-
# run: sudo apt-get -yq install doxygen doxygen-doc doxygen-latex doxygen-gui graphviz
260258
run: |
259+
# The Doxygen apt-get version for Ubuntu 20 is 1.8.17, which has some bugs fixed in 1.9.1
260+
# run: sudo apt-get -yq install doxygen doxygen-doc doxygen-latex doxygen-gui graphviz
261261
git clone https://github.com/doxygen/doxygen.git && cd doxygen && git checkout Release_1_9_1
262262
mkdir build && cd build
263263
cmake -G "Unix Makefiles" ..
@@ -272,6 +272,8 @@ jobs:
272272
echo 'Creating .nojekyll and copying log...'
273273
echo "" > doxygen/html/.nojekyll
274274
cp doxygen.log doxygen/html/doxygen.log
275+
# Required so Doxygen links/finds the license file
276+
cp LICENSE doxygen/html/LICENSE
275277
# Required in order to link .github/media/ images with doc without modifying doc links. Remove if using `publish_dir: doxygen/html/`
276278
mkdir -p doxygen_final/web/html/ && mv doxygen/html doxygen_final/web/html/doc
277279
mkdir -p doxygen_final/web/.github/media/ && cp -rf .github/media/ doxygen_final/web/.github/

README.md

+27-36
Original file line numberDiff line numberDiff line change
@@ -10,7 +10,7 @@
1010

1111
[**OpenPose**](https://github.com/CMU-Perceptual-Computing-Lab/openpose) has represented the **first real-time multi-person system to jointly detect human body, hand, facial, and foot keypoints (in total 135 keypoints) on single images**.
1212

13-
It is **authored by** [**Ginés Hidalgo**](https://www.gineshidalgo.com), [**Zhe Cao**](https://people.eecs.berkeley.edu/~zhecao), [**Tomas Simon**](http://www.cs.cmu.edu/~tsimon), [**Shih-En Wei**](https://scholar.google.com/citations?user=sFQD3k4AAAAJ&hl=en), [**Hanbyul Joo**](https://jhugestar.github.io), **and** [**Yaser Sheikh**](http://www.cs.cmu.edu/~yaser). It is **maintained by** [**Ginés Hidalgo**](https://www.gineshidalgo.com) **and** [**Yaadhav Raaj**](https://www.raaj.tech). OpenPose would not be possible without the [**CMU Panoptic Studio dataset**](http://domedb.perception.cs.cmu.edu). We would also like to thank all the people who [has helped OpenPose in any way](doc/8_authors_and_contributors.md).
13+
It is **authored by** [**Ginés Hidalgo**](https://www.gineshidalgo.com), [**Zhe Cao**](https://people.eecs.berkeley.edu/~zhecao), [**Tomas Simon**](http://www.cs.cmu.edu/~tsimon), [**Shih-En Wei**](https://scholar.google.com/citations?user=sFQD3k4AAAAJ&hl=en), [**Hanbyul Joo**](https://jhugestar.github.io), **and** [**Yaser Sheikh**](http://www.cs.cmu.edu/~yaser). It is **maintained by** [**Ginés Hidalgo**](https://www.gineshidalgo.com) **and** [**Yaadhav Raaj**](https://www.raaj.tech). OpenPose would not be possible without the [**CMU Panoptic Studio dataset**](http://domedb.perception.cs.cmu.edu). We would also like to thank all the people who [has helped OpenPose in any way](doc/09_authors_and_contributors.md).
1414

1515

1616

@@ -27,47 +27,42 @@ It is **authored by** [**Ginés Hidalgo**](https://www.gineshidalgo.com), [**Zhe
2727
2. [Features](#features)
2828
3. [Related Work](#related-work)
2929
4. [Installation](#installation)
30-
5. [Quick Start](#quick-start)
30+
5. [Quick Start Overview](#quick-start-overview)
3131
6. [Send Us Feedback!](#send-us-feedback)
3232
7. [Citation](#citation)
3333
8. [License](#license)
3434

3535

3636

3737
## Results
38-
### Body and Foot Estimation
38+
### Whole-body (Body, Foot, Face, and Hands) 2D Pose Estimation
3939
<p align="center">
40-
<img src=".github/media/dance_foot.gif" width="360">
40+
<img src=".github/media/dance_foot.gif" width="310">
41+
<img src=".github/media/pose_face.gif" width="310">
42+
<img src=".github/media/pose_hands.gif" width="310">
4143
<br>
42-
<sup>Testing the <a href="https://www.youtube.com/watch?v=2DiQUX11YaY" target="_blank"><i>Crazy Uptown Funk flashmob in Sydney</i></a> video sequence with OpenPose</sup>
44+
<sup>Testing OpenPose: (Left) <a href="https://www.youtube.com/watch?v=2DiQUX11YaY" target="_blank"><i>Crazy Uptown Funk flashmob in Sydney</i></a> video sequence. (Center and right) Authors <a href="https://www.gineshidalgo.com" target="_blank">Ginés Hidalgo</a> and <a href="http://www.cs.cmu.edu/~tsimon" target="_blank">Tomas Simon</a> testing face and hands</sup>
4345
</p>
4446

45-
### 3D Reconstruction Module (Body, Foot, Face, and Hands)
47+
### Whole-body 3D Pose Reconstruction and Estimation
4648
<p align="center">
4749
<img src=".github/media/openpose3d.gif" width="360">
4850
<br>
49-
<sup>Testing the 3D Reconstruction Module of OpenPose</sup>
50-
</p>
51-
52-
### Body, Foot, Face, and Hands Estimation
53-
<p align="center">
54-
<img src=".github/media/pose_face.gif" width="360">
55-
<img src=".github/media/pose_hands.gif" width="360">
56-
<br>
57-
<sup>Authors <a href="https://www.gineshidalgo.com" target="_blank">Ginés Hidalgo</a> (left image) and <a href="http://www.cs.cmu.edu/~tsimon" target="_blank">Tomas Simon</a> (right image) testing OpenPose</sup>
51+
<sup><a href="https://ziutinyat.github.io/" target="_blank">Tianyi Zhao</a> testing the OpenPose 3D Module</a></sup>
5852
</p>
5953

6054
### Unity Plugin
6155
<p align="center">
62-
<img src=".github/media/unity_main.png" width="240">
63-
<img src=".github/media/unity_body_foot.png" width="240">
64-
<img src=".github/media/unity_hand_face.png" width="240">
56+
<img src=".github/media/unity_main.png" width="310">
57+
<img src=".github/media/unity_body_foot.png" width="310">
58+
<img src=".github/media/unity_hand_face.png" width="310">
6559
<br>
6660
<sup><a href="https://ziutinyat.github.io/" target="_blank">Tianyi Zhao</a> and <a href="https://www.gineshidalgo.com" target="_blank">Ginés Hidalgo</a> testing the <a href="https://github.com/CMU-Perceptual-Computing-Lab/openpose_unity_plugin" target="_blank">OpenPose Unity Plugin</a></sup>
6761
</p>
6862

6963
### Runtime Analysis
7064
We show an inference time comparison between the 3 available pose estimation libraries (same hardware and conditions): OpenPose, Alpha-Pose (fast Pytorch version), and Mask R-CNN. The OpenPose runtime is constant, while the runtime of Alpha-Pose and Mask R-CNN grow linearly with the number of people. More details [**here**](https://arxiv.org/abs/1812.08008).
65+
7166
<p align="center">
7267
<img src=".github/media/openpose_vs_competition.png" width="360">
7368
</p>
@@ -91,30 +86,30 @@ We show an inference time comparison between the 3 available pose estimation lib
9186
- **OS**: Ubuntu (20, 18, 16, 14), Windows (10, 8), Mac OSX, Nvidia TX2.
9287
- **Hardware compatibility**: CUDA (Nvidia GPU), OpenCL (AMD GPU), and non-GPU (CPU-only) versions.
9388
- **Usage Alternatives**:
94-
- [**Command-line demo**](doc/1_demo.md) for built-in functionality.
95-
- [**C++ API**](examples/tutorial_api_cpp/) and [**Python API**](doc/3_python_api.md) for custom functionality. E.g., adding your custom inputs, pre-processing, post-posprocessing, and output steps.
89+
- [**Command-line demo**](doc/01_demo.md) for built-in functionality.
90+
- [**C++ API**](doc/04_cpp_api.md/) and [**Python API**](doc/03_python_api.md) for custom functionality. E.g., adding your custom inputs, pre-processing, post-posprocessing, and output steps.
9691

97-
For further details, check the [major released features](doc/6_major_released_features.md) and [release notes](doc/7_release_notes.md) docs.
92+
For further details, check the [major released features](doc/07_major_released_features.md) and [release notes](doc/08_release_notes.md) docs.
9893

9994

10095

10196
## Related Work
10297
- [**OpenPose training code**](https://github.com/CMU-Perceptual-Computing-Lab/openpose_train)
10398
- [**OpenPose foot dataset**](https://cmu-perceptual-computing-lab.github.io/foot_keypoint_dataset/)
10499
- [**OpenPose Unity Plugin**](https://github.com/CMU-Perceptual-Computing-Lab/openpose_unity_plugin)
105-
- OpenPose papers published in [**IEEE TPAMI** and **CVPR**](#citation). [Cite them](#citation) in your publications if it helps your research!
100+
- OpenPose papers published in **IEEE TPAMI and CVPR**. Cite them in your publications if OpenPose helps your research! (Links and more details in the [Citation](#citation) section below).
106101

107102

108103

109104
## Installation
110-
If you want to use OpenPose without compiling or writing any code, simply [download and use the latest Windows portable version of OpenPose](doc/installation/0_index.md#windows-portable-demo)! Otherwise, you can also [build OpenPose from source](doc/installation/0_index.md#compiling-and-running-openpose-from-source).
105+
If you want to use OpenPose without installing or writing any code, simply [download and use the latest Windows portable version of OpenPose](doc/installation/0_index.md#windows-portable-demo)!
111106

112-
See [doc/installation/0_index.md](doc/installation/0_index.md) for more details.
107+
Otherwise, you could [build OpenPose from source](doc/installation/0_index.md#compiling-and-running-openpose-from-source). See the [installation doc](doc/installation/0_index.md) for all the alternatives.
113108

114109

115110

116-
## Quick Start
117-
Most users do not need to know C++ or Python, they can simply use the OpenPose Demo in their command-line tool (e.g., PowerShell/Terminal). E.g., this would run OpenPose on the webcam and display the body keypoints:
111+
## Quick Start Overview
112+
Simply use the OpenPose Demo from your favorite command-line tool (e.g., Windows PowerShell or Ubuntu Terminal). E.g., this example runs OpenPose on your webcam and displays the body keypoints:
118113
```
119114
# Ubuntu
120115
./build/examples/openpose/openpose.bin
@@ -124,7 +119,7 @@ Most users do not need to know C++ or Python, they can simply use the OpenPose D
124119
bin\OpenPoseDemo.exe --video examples\media\video.avi
125120
```
126121

127-
You can also add any of the available flags in any order. Do you also want to add face and/or hands? Add the `--face` and/or `--hand` flags. Do you also want to save the output keypoints on JSON files on disk? Add the `--write_json` flag, etc.
122+
You can also add any of the available flags in any order. E.g., the following example runs on a video (`--video {PATH}`), enables face (`--face`) and hands (`--hand`), and saves the output keypoints on JSON files on disk (`--write_json {PATH}`).
128123
```
129124
# Ubuntu
130125
./build/examples/openpose/openpose.bin --video examples/media/video.avi --face --hand --write_json output_json_folder/
@@ -134,23 +129,19 @@ You can also add any of the available flags in any order. Do you also want to ad
134129
bin\OpenPoseDemo.exe --video examples\media\video.avi --face --hand --write_json output_json_folder/
135130
```
136131

137-
After [installing](#installation) OpenPose, check [doc/0_index.md](doc/0_index.md) for a quick overview of all the alternatives and tutorials.
132+
Optionally, you can also extend OpenPose's functionality from its Python and C++ APIs. After [installing](doc/installation/0_index.md) OpenPose, check its [official doc](doc/00_index.md) for a quick overview of all the alternatives and tutorials.
138133

139134

140135

141136
## Send Us Feedback!
142-
Our library is open source for research purposes, and we want to continuously improve it! So let us know if you...
143-
1. Find any bug (in functionality or speed).
144-
2. Add some functionality on top of OpenPose which we might want to add.
145-
3. Know how to speed up or improve any part of OpenPose.
146-
4. Want to share your cool demo or project made on top of OpenPose (you can email it to us too!).
147-
148-
Just create a new GitHub issue or a pull request and we will answer as soon as possible!
137+
Our library is open source for research purposes, and we want to improve it! So let us know (create a new GitHub issue or pull request, email us, etc.) if you...
138+
1. Find/fix any bug (in functionality or speed) or know how to speed up or improve any part of OpenPose.
139+
2. Want to add/show some cool functionality/demo/project made on top of OpenPose. We can add your project link to our [Community-based Projects](doc/10_community_projects.md) section or even integrate it with OpenPose!
149140

150141

151142

152143
## Citation
153-
Please cite these papers in your publications if it helps your research. All of OpenPose is based on [OpenPose: Realtime Multi-Person 2D Pose Estimation using Part Affinity Fields](https://arxiv.org/abs/1812.08008), while the hand and face detectors also use [Hand Keypoint Detection in Single Images using Multiview Bootstrapping](https://arxiv.org/abs/1704.07809) (the face detector was trained using the same procedure than the hand detector).
144+
Please cite these papers in your publications if OpenPose helps your research. All of OpenPose is based on [OpenPose: Realtime Multi-Person 2D Pose Estimation using Part Affinity Fields](https://arxiv.org/abs/1812.08008), while the hand and face detectors also use [Hand Keypoint Detection in Single Images using Multiview Bootstrapping](https://arxiv.org/abs/1704.07809) (the face detector was trained using the same procedure than the hand detector).
154145

155146
@article{8765346,
156147
author = {Z. {Cao} and G. {Hidalgo Martinez} and T. {Simon} and S. {Wei} and Y. A. {Sheikh}},

doc/0_index.md doc/00_index.md

+8-10
Original file line numberDiff line numberDiff line change
@@ -2,16 +2,16 @@ OpenPose Doc
22
==========================
33

44
The OpenPose documentation is available in 2 different formats, choose your preferred one!
5-
- As a traditional website (recommended): [cmu-perceptual-computing-lab.github.io/openpose/web/html/doc](https://cmu-perceptual-computing-lab.github.io/openpose/web/html/doc/).
6-
- As markdown files: [github.com/CMU-Perceptual-Computing-Lab/openpose/blob/master/doc/0_index.md](https://github.com/CMU-Perceptual-Computing-Lab/openpose/blob/master/doc/0_index.md).
5+
- As a traditional website (recommended): [cmu-perceptual-computing-lab.github.io/openpose/web/html/doc/](https://cmu-perceptual-computing-lab.github.io/openpose/web/html/doc/).
6+
- As markdown files: [github.com/CMU-Perceptual-Computing-Lab/openpose/blob/master/doc/00_index.md](https://github.com/CMU-Perceptual-Computing-Lab/openpose/blob/master/doc/00_index.md).
77

88
Most users can simply use the OpenPose Demo without reading any C++/Python code. Users that need to add additional functionality (new inputs, outputs, etc) should check the C++/Python APIs:
99

10-
- If you face issues with any of these steps, keep in mind to check the [FAQ](installation/4_faq.md) section.
10+
- If you face issues with any of these steps, keep in mind to check the [FAQ](installation/05_faq.md) section.
1111

1212
- The first step for any software, [install it](installation/0_index.md)!
1313

14-
- [OpenPose Demo](1_demo.md): Choose your input (e.g., images, video, webcam), set of algorithms (body, hand, face), output (e.g., display, JSON keypoint saving, image+keypoints), and run OpenPose from your terminal or PowerShell!
14+
- [OpenPose Demo](01_demo.md): Choose your input (e.g., images, video, webcam), set of algorithms (body, hand, face), output (e.g., display, JSON keypoint saving, image+keypoints), and run OpenPose from your terminal or PowerShell!
1515
- E.g.: Given an input video (`--video`), extract body (by default), face (`--face`) and hand (`--hand`) keypoints, save the keypoints in a JSON file (`--write_json`), and display (by default) the results in the screen. You can remove any of the flags to remove that particular functionality or add any other.
1616
```
1717
# Ubuntu
@@ -21,15 +21,13 @@ Most users can simply use the OpenPose Demo without reading any C++/Python code.
2121
bin\OpenPoseDemo.exe --video examples\media\video.avi --face --hand --write_json output_json_folder/
2222
```
2323

24-
- [Output information](2_output.md): Learn about the output format, keypoint index ordering, etc.
24+
- [Output information](02_output.md): Learn about the output format, keypoint index ordering, etc.
2525

26-
- [OpenPose Python API](3_python_api.md): Almost all the OpenPose functionality, but in Python!
26+
- [OpenPose Python API](03_python_api.md): Almost all the OpenPose functionality, but in Python! If you want to read a specific input, and/or add your custom post-processing function, and/or implement your own display/saving.
2727

28-
- [OpenPose C++ API](../examples/tutorial_api_cpp/): If you want to read a specific input, and/or add your custom post-processing function, and/or implement your own display/saving.
29-
- You should be familiar with the [OpenPose Demo](1_demo.md) and the main OpenPose flags before trying to read the C++ or Python API examples. Otherwise, it will be way harder to follow.
30-
- For quick prototyping: You can easily **create your custom code** on [examples/user_code/](../examples/user_code/) and CMake will automatically compile it together with the whole OpenPose project. See [examples/user_code/README.md](../examples/user_code/README.md) for more details.
28+
- [OpenPose C++ API](04_cpp_api.md): If you want to read a specific input, and/or add your custom post-processing function, and/or implement your own display/saving.
3129

32-
- [Maximizing OpenPose speed and benchmark](5_maximizing_openpose_speed.md): Check the OpenPose Benchmark as well as some hints to speed up and/or reduce the memory requirements for OpenPose.
30+
- [Maximizing OpenPose speed and benchmark](06_maximizing_openpose_speed.md): Check the OpenPose Benchmark as well as some hints to speed up and/or reduce the memory requirements for OpenPose.
3331

3432
- [Calibration toolbox](advanced/calibration_module.md) and [3D OpenPose](advanced/3d_reconstruction_module.md): Calibrate your cameras for 3D OpenPose (or any other stereo vision tasks) and start obtaining 3D keypoints!
3533

0 commit comments

Comments
 (0)