Metadata-Version: 2.1
Name: axopy
Version: 0.2.0
Summary: Human-computer interface experimentation library
Home-page: https://github.com/axopy/axopy
Author: Kenneth Lyons
Author-email: ixjlyons@gmail.com
License: MIT
Keywords: human computer interface control electrophysiology
Platform: UNKNOWN
Classifier: Development Status :: 4 - Beta
Classifier: License :: OSI Approved :: MIT License
Classifier: Environment :: X11 Applications :: Qt
Classifier: Intended Audience :: Science/Research
Classifier: Operating System :: OS Independent
Classifier: Topic :: Scientific/Engineering :: Human Machine Interfaces
Classifier: Topic :: Scientific/Engineering :: Medical Science Apps.
Classifier: Programming Language :: Python :: 2
Classifier: Programming Language :: Python :: 2.7
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.4
Classifier: Programming Language :: Python :: 3.5
Classifier: Programming Language :: Python :: 3.6
Requires-Dist: numpy
Requires-Dist: scipy
Requires-Dist: pandas
Requires-Dist: h5py
Requires-Dist: pyqt5
Requires-Dist: pyqtgraph (>=0.10)
Provides-Extra: dev
Requires-Dist: pytest ; extra == 'dev'
Requires-Dist: pytest-cov ; extra == 'dev'
Requires-Dist: pytest-qt ; extra == 'dev'
Requires-Dist: pytest-mock ; extra == 'dev'
Requires-Dist: pytest-xvfb ; extra == 'dev'
Requires-Dist: flake8 ; extra == 'dev'
Requires-Dist: sphinx ; extra == 'dev'
Requires-Dist: sphinx-rtd-theme ; extra == 'dev'

.. image:: docs/_static/axopy.png
   :alt: AxoPy Logo

|

.. image:: https://travis-ci.org/axopy/axopy.svg?branch=master
    :target: https://travis-ci.org/axopy/axopy
    :alt: Travis CI Status

.. image:: https://readthedocs.org/projects/axopy/badge/?version=latest
   :target: http://axopy.readthedocs.io/en/latest/?badge=latest
   :alt: Documentation Status

.. image:: https://codecov.io/gh/axopy/axopy/branch/master/graph/badge.svg
   :target: https://codecov.io/gh/axopy/axopy
   :alt: Codecov test coverage

|

Axo-Pythonic synapses are those in which an axon synapses upon a Python
program. AxoPy aims to facilitate such connections between electrophysiolgical
signals and machines by making it easy for researchers to develop
human-computer interface experiments. If you've ever found yourself spending
more time thinking about how to implement your experiments than thinking about
*what the experiment should be*, AxoPy may be able to help.

AxoPy consists of:

Graphical interface
    Central to AxoPy is the graphical user interface providing visual feedback
    to the subject and controlling the flow of the experiment. The GUI is
    backed by PyQt5, and you're free to implement customized graphical elements
    if those built in to AxoPy don't suit your needs.
Data acquisition
    AxoPy establishes a fairly simple API for communicating with input
    hardware, so all that's usually needed is a bit of middleware to get going.
    Check out pytrigno_ or pymcc_ to see what this is like. A couple input
    devices are built in (keyboard, noise generator), so examples run without
    needing special hardware.
Data storage
    Data is stored in a file structure with common file formats (CSV and HDF5)
    so you can a) start working with data as soon as an experiment session is
    over and b) you don't need anything but standard tools (pandas, h5py) to do
    so. A high-level interface to the storage structure is also provided to
    make traversing a dataset simple.
Pipeline processing
    Estimating intentions of the user from raw electrophysiological signals
    often involves a large number of processing operations. AxoPy facilitates
    flexible construction of pipelines that can be reused in different parts of
    an experiment and re-used for offline post-processing, etc.


Quickstart
==========

Installation
------------

pip
^^^

AxoPy is available on `PyPI`_, so the following should get it installed if
you're using a standard Python installation with ``pip``::

    $ pip install axopy

*Note*: if you have Python < 3.5, ``pip`` will not be able to install the
``pyqt5`` package for you because wheels for ``pyqt5`` are only provided for
Python >= 3.5. If you are stuck on an older version of Python, consider using
``conda`` (described below, works for any Python version) or installing Qt5 and
PyQt5 yourself before running the command above.

See the `development documentation`_ for information on setting up
a development environment to work on AxoPy itself.

conda
^^^^^

AxoPy is also available on `conda-forge`_, so if you're using (Ana)conda with
any Python version, you can install it with::

    $ conda install -c conda-forge axopy

Hello, AxoPy
------------

Here's a minimal example to display some randomly generated signals in an
"oscilloscope":

.. code-block:: python

    import axopy

    daq = axopy.daq.NoiseGenerator(rate=1000, num_channels=4, read_size=100)
    exp = axopy.experiment.Experiment(daq=daq)
    exp.run(axopy.task.Oscilloscope())


Next Steps
----------

Check out the documentation_ for more information on creating experiments. Some
`examples`_ are also available.


Contributing
============

Please feel free to share any thoughts or opinions about the design and
implementation of this software by `opening an issue on GitHub
<https://github.com/axopy/axopy/issues/new>`_. Constructive feedback is
welcomed and appreciated.

GitHub issues also serve as the support channel, at least for now. Questions
about how to do something are usually great opportunities to improve
documentation, so you may be asked about your thoughts on where the answers
should go.

If you want to contribute code, open a pull request. Bug fix pull requests are
always welcome. For feature additions, breaking changes, etc. check if there is
an open issue discussing the change and reference it in the pull request. If
there isn't one, it is recommended to open one with your rationale for the
change before spending significant time preparing the pull request.

Ideally, new/changed functionality should come with tests and documentation. If
you are new to contributing, it is perfectly fine to open a work-in-progress
pull request and have it iteratively reviewed. See the `development
documentation`_ for instructions on setting up a development environment,
running tests, and building the documentation.


.. _pytrigno: https://github.com/axopy/pytrigno
.. _pymcc: https://github.com/axopy/pymcc
.. _documentation: https://axopy.readthedocs.io
.. _examples: https://github.com/axopy/axopy/tree/master/examples
.. _PyPI: https://pypi.org/
.. _conda-forge: https://conda-forge.org/
.. _conda: https://conda.io/docs/
.. _development documentation: http://axopy.readthedocs.io/en/latest/development.html


