Skip to main content

A tool for reading, writing and generally working with 9ML objects and files.

Project description

NineML Python Library
=====================

.. image:: https://travis-ci.org/INCF/nineml-python.svg?branch=master
:target: https://travis-ci.org/ICNF/nineml-python
:alt: Unit Test Status
.. image:: https://coveralls.io/repos/github/INCF/nineml-python/badge.svg?branch=master
:target: https://coveralls.io/github/INCF/nineml-python?branch=master
:alt: Unit Test Coverage
.. image:: https://img.shields.io/pypi/pyversions/nineml.svg
:target: https://pypi-hypernode.com/pypi/nineml/
:alt: Supported Python versions
.. image:: https://img.shields.io/pypi/v/nineml.svg
:target: https://pypi-hypernode.com/pypi/nineml/
:alt: Latest Version
.. image:: https://readthedocs.org/projects/nineml-python/badge/?version=latest
:target: http://nineml-python.readthedocs.io/en/latest/?badge=latest
:alt: Documentation Status

NineML (9ML) is a language for describing the dynamics and connectivity of
neuronal network simulations (http://nineml.net), which is defined by the
`NineML specification`_.

The NineML Python Library is a software package written in Python, which maps
the NineML object model onto Python classes for convenient creation,
manipulation and validation of NineML models, as well as handling their
serialisation to and from XML_, JSON_, YAML_, and HDF5_.


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

HDF5
~~~~

To add support to read or write HDF5_ serialisations you must first install the
HDF5_ library.

On macOS it can be installed using Homebrew_

$ brew install hdf5

On Ubuntu/Debian it can be installed via the following packages:

* libhdf5-serial-dev (serial)
* libhdf5-openmpi-dev (parallel with Open MPI)
* libhdf5-mpich-dev (parallel with MPICH)

.. note: If you don't install a HDF5_ other serialisations can
still be used but you will need to install the package manually.

Pip
~~~

The NineML Python Library can be installed using ``pip``

$ pip install nineml


Relation to the NineML Specification
------------------------------------

The layout of the Python modules and classes in the NineML Python Library
relates closely to the structure of the `NineML specification v1.0`_. However,
there are notable exceptions where the NineML Python Library uses names and
relationships that are planned to be changed in v2.0 of the specification
(the NineML Python Library will be backwards compatible), such as the
renaming of ``ComponentClass`` elements to separate ``Dynamics``,
``ConnectionRule`` and ``RandomDistribution`` elements
(see https://github.com/INCF/nineml/issues/94).
A full list of changes planned for NineML v2.0 can be found at
https://github.com/INCF/nineml/milestone/3. When serializing 9ML models
the version 1.0 syntax is used unless the ``version=2.0`` keyword argument is
used.

In addition to classes that directly correspond to the 9ML object model, a
range of shorthand notations ("syntactic sugar") exist to make writing 9ML
models by hand more convenient (see the *nineml.sugar* module). These notations
are frequently demonstrated in the *examples* directory of the repository.


NineML Catalog
--------------

The `NineML Catalog`_ contains a collection of validated NineML models, which
can be loaded and maninpulated with the NineML Python Library. If you create a
model that you believe will be of wider use to the computational neuroscience
community please consider contributing to the catalog via a pull request.


Links
-----

* Documentation: http://nineml-python.readthedocs.org
* Mailing list: `NeuralEnsemble Google Group`_
* Issue tracker: https://github.com/INCF/nineml-python/issues


:copyright: Copyright 20011-2017 by the NineML Python Library team, see AUTHORS.
:license: BSD 3, see LICENSE for details.

.. _HDF5: http://support.hdfgroup.org/HDF5/
.. _YAML: http://yaml.org
.. _JSON: http://www.json.org
.. _XML: http://www.w3.org/XML/
.. _h5py: http://h5py.org/
.. _pyyaml: http://pyyaml.org/
.. _sympy: http://sympy.org
.. _lxml: http://pypi.python.org/pypi/lxml
.. _virtualenv: https://virtualenv.readthedocs.io/en/latest/
.. _Homebrew: https://brew.sh/
.. _NineML specification: http://nineml-spec.readthedocs.io
.. _`NeuralEnsemble Google Group`: http://groups.google.com/group/neuralensemble
.. _`NineML Catalog`: http://github.com/INCF/nineml-catalog



Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

nineml-1.0rc1.tar.gz (3.8 MB view details)

Uploaded Source

Built Distribution

nineml-1.0rc1-py2.py3-none-any.whl (257.8 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file nineml-1.0rc1.tar.gz.

File metadata

  • Download URL: nineml-1.0rc1.tar.gz
  • Upload date:
  • Size: 3.8 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for nineml-1.0rc1.tar.gz
Algorithm Hash digest
SHA256 4295a65aed86d82c7ed470d1e466011b642632559bcd83a9b04a180e8c2c3032
MD5 91fe5e41c89309803c036981362dd94e
BLAKE2b-256 40addc65fd215c717c92119149104371b56b74aa32e1b1fecfef5637af467cb7

See more details on using hashes here.

File details

Details for the file nineml-1.0rc1-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for nineml-1.0rc1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 1c23fe908b393ac78f6b9ce4ebad341c867e1735e02b61b706bb41344c58518b
MD5 ca3c30a777e443069c9d6d60a3f819f6
BLAKE2b-256 182567fcf106b63c515e86b41c579809fbdee6468abc2b0efba497017da087d8

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page