A tool for reading, writing and generally working with 9ML objects and files.
Project description
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 (dev)
To add support to read or write HDF5 serialisations you must first install a HDF5 dev library (i.e. with headers).
On macOS HDF5 can be installed using Homebrew
$ brew install hdf5
On Ubuntu/Debian HDF5 can be installed via the following packages:
libhdf5-serial-dev (serial)
libhdf5-openmpi-dev (parallel with Open MPI)
libhdf5-mpich-dev (parallel with MPICH)
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.
The 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.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file nineml-1.0rc2.tar.gz
.
File metadata
- Download URL: nineml-1.0rc2.tar.gz
- Upload date:
- Size: 3.8 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d2a711a0a490e5ae2d38ef1b3380435bf61aac148bb260f2c00a284426b461f5 |
|
MD5 | fb580237a2a156f8559420c23547812d |
|
BLAKE2b-256 | b79ef2611491478af2ecd55c74ac2ef8adf825be6d327916043b4abe910dd051 |
File details
Details for the file nineml-1.0rc2-py2.py3-none-any.whl
.
File metadata
- Download URL: nineml-1.0rc2-py2.py3-none-any.whl
- Upload date:
- Size: 257.8 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5fc1cc74daedd7a67eb394ab21771cb141dbe5d37fd2f685e1fbc3dbc94d222e |
|
MD5 | 94497e8caf47f38240dcd1bc703ffd52 |
|
BLAKE2b-256 | 26a842ad4062d40f7e1c71d6195814d47a9b8a4c55b310f9d1d943a7a57d6a36 |