项目作者: OpenISS

项目描述 :
OpenISS -- a unified multimodal motion data delivery framework.
高级语言: C
项目地址: git://github.com/OpenISS/OpenISS.git
创建时间: 2016-10-23T03:54:58Z
项目社区:https://github.com/OpenISS/OpenISS

开源协议:Apache License 2.0

下载


OpenISS

CII Best Practices

OpenISS is a motion capture data aggregation and delivery framework for VFX that
has library instances abstracting various middleware and cameras for many application types.

Applications include AI+Art, performing arts, interactive film, facial animation,
NUI applications using OpenGL, Processing, TensorFlow, Keras, and MARF.

The OpenISS framework provides a uniform abstraction layer over libfreenect,
libfreenect2, librealsense, OpenNI2, NiTE2, NuiTrack, Azure SDK, PCL, and ROS and has
REST and SOAP web services. There are different front-end modules as
well based on OpenGL, Processing, and web browsers (JS).

The public GitHub updates are done periodically from private forks where
a lot of integration / contributions happen.

History

OpenISS is inspired by the development of ISSv1, ISSv2, ISSv3 and MultiCamTk++, but is being built
from scratch using C/C++ and various wrappers and uses similar or same open-source libraries, middleware and toolkits for
sensors and creative coding. Various wrappers are being developed. See background on the inspirational ISS below.
OpenISS API is likewise for the first time made it possble to access Kinect 1 and 2
as well as OpenCV as REST and SOAP services for creative near-realtime online broadcasting.
OpenISS is poised to be the core replacement for ISSv2’s pipeline. It also serves as
an educational tool for graduate and undergraduate students in computer vision, computation
arts, pattern recognition, AI, machine learning, and game development. It is designed
to be portable.

  • OpenISS component development began in 2016 in C
  • Expanded to C++ and Java since and ongoing

Contributors

Current

  • Kyle Ross, Unity plugin and related rigging
  • Konstantinos (Kosta) Psimoulis: Web Services lead (REST and SOAP), SimpleOpenNIRS/liblrealsense2 support
  • Jonathan Llewellyn: actvity/action recognition, VFX pipeline
  • Dominique Cartier, point clouds integration and object/surface reconstruction

Recent

  • Jashanjot Singh: Gesture and Hand Tracking Framework, NiTE2/NuiTrack, and ROS support, SWIG support for Java/Processing
  • Haotao (Eric) Lai: Person Re-identifcation, Green Screening, device abstracion (Kinects 1 and 2, RealSense D435), TensorFlow/Keras/Python abstractions; Kinect 2 web service
  • Yiran (Bernie) Shen: Facial Recognition and data (landmarks and expressions) provider framework abstraction over OpenFace, OpenCV, including TensortFlow for VFX
  • Yuhao Mao: Art and AI, Sound Visualization, Style Transfer
  • Chao Wang: Style Transfer, Magenta support, motion-based audio support, finger tracking
  • Zihao Song: Singnal Processing for Audio and Image Processing effects and MARF

Web Services

  • See here for more documentation.

Early C API and Linux Builds

  • See detailed list here.
  • Updates for Linux and C in EL6 (CentOS 6.x), CSI230-101 Fall 2017 course students teams:

    • Calum Phillips, Rosser Martinez, Matthew Roy
    • Alex Rader, Cory Smith, Nicholas Robbins
  • Original build automation contributors for Linux in EL6 (CentOS 6.x), CSI230-101 Fall 2016 course students teams:

    • Brian Baron, Colin Brady, Robert Gentile
    • Gabriel Pereyra, Justin Mulkin, Duncan Carrol, Lucas Spiker

Build Instructions

Docker

  • We are working on our Docker images here

Ubuntu

  • Please use cmake
  • More documentation to follow

MacOS

  • Please use cmake
  • More documentation to follow

EL7

EL7 (RHEL, CentOS, Scientific Linux) are as of September 2018 default and
preferred build, so the development effort focuses around this platform,
but it is known to run on macOS and Ubuntu.

EL6

EL6 is now considered legacy.

Notice, EL6 requires a newer kernel for
proper USB3 and NVIDIA support. If you prefer
to install dependencies manually, you can follow
the scripts referenced here (build.sh and el6.sh) and repeat their
relevant steps one by one.

  1. Install:
  2. yum install git
  3. git clone https://github.com/OpenISS/OpenISS.git
  4. git submodule update --init --recursive
  5. Navigate to OpenISS/src
  6. Run the command:
  7. make deps
  8. This will install all of the 3rd party
  9. dependencies
  10. Compile:
  11. cd OpenISS/src
  12. make
  13. Clean:
  14. Navigate to OpenISS/src
  15. Run the command:
  16. make clean
  17. Removes the installed dependencies

TODO

Build Support

  • OS X (mostly there)
  • Windows (partially there for some components)

Wrappers

  • Java (in progress)
  • C++ (mostly there)
  • Processing (in progress)
  • Max (in progress)
  • PureData (in progress)
  • Python (started)

Background on the ISSv1, ISSv2, ISSv3

OpenISS’s core goals are to enable achieving something akin
to the original ISS below in an open educational setting. Then,
to build custom applications based on it, using OpenISS API
as a core.

Academic Publications

Videos

References and Acknowledgements