/psmoveapi

PS Move Controller Low-Level API

Primary LanguageCOtherNOASSERTION

            ____  _____    __  ___                   ___    ____  ____
           / __ \/ ___/   /  |/  /___ _   _____     /   |  / __ \/  _/
          / /_/ /\__ \   / /|_/ / __ \ | / / _ \   / /| | / /_/ // /
         / ____/___/ /  / /  / / /_/ / |/ /  __/  / ___ |/ ____// /
        /_/    /____/  /_/  /_/\____/|___/\___/  /_/  |_/_/   /___/

                                   http://thp.io/2010/psmove/


The PS Move API is an open source[1] library for Linux, Mac OS X and Windows
to access the Sony Move Motion Controller via Bluetooth and USB directly from
your PC without the need for a PS3. Tracking in 3D space is possible using a
PS Eye (on Linux and Windows), an iSight camera (on Mac OS X) or any other
suitable camera source.

The PS Move API is used as the library implementation of the MoveOnPC[2]
project, and has successfully participated in Google Summer of Code 2012[3].
Detailed documentation can be found in my master's thesis[4] about sensor
fusion.


Core Features
-------------

 * Pairing of Bluetooth controllers via USB
 * Setting LEDs and rumble via USB and Bluetooth
 * Reading inertial sensors and buttons via Bluetooth
 * Tracking up to 5 controllers in 3D space via OpenCV
 * 3D orientation tracking via an open source AHRS algorithm
 * Sensor fusion for augmented and virtual reality applications

Supported Languages
-------------------

 * Core library written in C for portability and performance
 * SWIG-based bindings for Python, Java, Processing and C#

Need Help?
----------

 * Free community-based support via the PS Move Mailing List[5]
 * Professional support and custom development upon request[6]

Building and Installation
-------------------------

 * See the INSTALL and README.* files for details on building and
   installing the PS Move API on your system
 * Build scripts that we use for building binary releases can be found
   in the contrib/ folder
 * A debian/ folder is provided for building .deb packages
 * Contributions (.spec files, etc..) for other distributions welcome

Hacking the Source
------------------

 * See the LAYOUT file for information on how the source tree is laid out
 * Coding style: No strict rules; keep consistent with the surrounding code
 * Patches should be submitted on Github as pull request[7]
 * Bug reports and feature requests can be added to the issue tracker[8]

Environment Variables
---------------------

 PSMOVE_TRACKER_CAMERA

     If set, this is the camera that will be used when using
     psmove_tracker_new() instead of using auto-detection

   Example: export PSMOVE_TRACKER_CAMERA=2  # Will use the 3rd camera

 PSMOVE_TRACKER_FILENAME

     If set, this will use a video file to playback instead of
     capturing from a camera. Any camera settings are ignored.

   Example: export PSMOVE_TRACKER_FILENAME=demo.avi # Will play demo.avi

 PSMOVE_TRACKER_ROI_SIZE

     If set, this controls the size of the biggest (initial) ROI that will
     be used to track the controller. Bigger means slower in general, but
     recovery from tracking loss might be faster.

   Example: export PSMOVE_TRACKER_ROI_SIZE=200

 PSMOVE_TRACKER_WIDTH, PSMOVE_TRACKER_HEIGHT

     If set, these variables control the desired size of the camera picture.

   Example: export PSMOVE_TRACKER_WIDTH=1280
            export PSMOVE_TRACKER_HEIGHT=720


Licensing
---------

The PS Move API source code is released under the terms of a Simplified
BSD-style license, the exact license text can be found in the COPYING file.

Some third party code under "external/" might be licensed under a different
license. Compiling PS Move API with these modules is optional, you can use
CMake options to configure which features you need. CMake will give you a
hint about the library licensing for your current configuration depending
on your options at configure time.

In general, all dependencies are under a MIT- or BSD-style license, with the
exception of the following dependencies:

 - Madgwick AHRS: Released under the terms of the GNU GPL
   For orientation tracking
   CMake option: PSMOVE_USE_MADGWICK_AHRS (disabled by default)

 - TUIO CPP: Released under the terms of the GNU GPL
   For the TUIO server example (only in the tuio_server binary)
   CMake option: PSMOVE_BUILD_TUIO_SERVER (disabled by default)

 - PS3EYEDriver: Released under the MIT license, parts based on GPL code
   For interfacing with the PSEye camera on OS X (only in the tracker)
   CMake option: PSMOVE_USE_PS3EYE_DRIVER (disabled by default)

When you enable the Madgwick AHRS algorithm, the resulting library can only
be used under the terms of the GNU GPL. Same with the TUIO Server, although
here only the "tuio_server" binary is affected, no the PS Move API library.

More information about the third party modules and licenses:

  - http://thp.io/2012/thesis/thesis.pdf (page 51-53)
  - File "external/README" in this source tree


More Information
----------------

 * License: Simplified BSD-style license (see COPYING and "Licensing" above)
 * Maintainer: Thomas Perl <m@thp.io>
 * Website: http://thp.io/2010/psmove/
 * Git repository: https://github.com/thp/psmoveapi
 * Mailing list: psmove@googlegroups.com (see [5] for details)


This README file was last updated on 2012-12-12 by thp


[1] https://github.com/thp/psmoveapi/blob/master/COPYING
[2] http://code.google.com/p/moveonpc/
[3] http://www.google-melange.com/gsoc/homepage/google/gsoc2012
[4] http://thp.io/2012/thesis/
[5] https://groups.google.com/forum/#!aboutgroup/psmove
[6] http://thp.io/about
[7] https://github.com/thp/psmoveapi/pulls
[8] https://github.com/thp/psmoveapi/issues