A Python package for the simulation of organoids for the purpose of studying Organoid Intelligence (OI) and Organoid Learning (OL).
Project description
PyOrganoid is the world's first* Python package for the simulation of organoids for the purpose of studying Organoid Intelligence (OI) and Organoid Learning (OL). It is designed to be simple to use and easy to extend with support for standard machine learning libraries such as TensorFlow, PyTorch, and Scikit-Learn (as well as ONNX-format models).
- Documentation: https://danielathome19.github.io/pyorganoid
- Source code: https://github.com/danielathome19/pyorganoid
- Bug reports: https://github.com/danielathome19/pyorganoid/issues
- Contributing: CONTRIBUTING.md
It provides:
- a simple and intuitive API
- support for standard machine learning libraries
- a growing library of organoid models
- visualization tools for organoid simulation
- numerous simulation environments and scheduling algorithms
- TODO: support for parallel/distributed computing, bio/cheminformatics libraries, logging, and more
PyOrganoid is currently in development and may not yet be ready for production use. We are actively seeking contributors to help us improve the package and expand its capabilities. If you are interested in contributing, please see our contributing guide.
*As of July 6th, 2024, to the best of our knowledge :)
Installation
Pip
PyOrganoid can be installed (without built-in support for machine learning libraries) using pip
:
pip install pyorganoid
To include support for all machine learning libraries, use:
pip install pyorganoid[all]
Or, to include support for a specific library (TensorFlow, PyTorch, Scikit-Learn, or ONNX), use:
pip install pyorganoid[tensorflow]
pip install pyorganoid[torch]
pip install pyorganoid[sklearn]
pip install pyorganoid[onnx]
Conda
PyOrganoid can also be installed using conda
:
conda install -c danielathome19 pyorganoid
To include support for extras, use pip as described above.
Quickstart
For a quick introduction to PyOrganoid, see the Spiking Neuron Test in the test
directory.
This test demonstrates the creation of a simple spiking neuron organoid running a binary classification Multi-Layer
Perceptron (MLP) model using TensorFlow.
If you prefer Scikit-Learn, PyTorch, or ONNX models, see the Volumetric Organoid Test (Scikit-Learn), the Gene Regulation Organoid Test (PyTorch), or the Immune Response Organoid Test (ONNX), respectively.
For example:
import pyorganoid as po
model = po.tf_module.TFModel("model.h5")
env = po.environments.Environment()
organoid = po.organoids.SpikingNeuronOrganoid(env, model, num_cells=50)
organoid.plot_organoid(show_properties=True)
scheduler = po.simulation.Scheduler(organoid)
scheduler.simulate(steps=100)
organoid.plot_simulation_history(title="Spiking Neuron Organoid Simulation",
y_label="Membrane Potential (mV)", dpi=600)
License
PyOrganoid is licensed under the BSD-3 License. See the LICENSE file for more information.
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
Built Distribution
File details
Details for the file pyorganoid-0.1.4.tar.gz
.
File metadata
- Download URL: pyorganoid-0.1.4.tar.gz
- Upload date:
- Size: 19.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.11.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 671f3fc39d6c3f2490348e2cadaa0cf3da499043fbb657ce6ee1836bccd64089 |
|
MD5 | 5eabe3864052f2698f0d179cdc378a67 |
|
BLAKE2b-256 | 0dba4e5157450acebf662074138712a3e1b70dfb8bf9d77bd21bafd076c9d451 |
File details
Details for the file pyorganoid-0.1.4-py3-none-any.whl
.
File metadata
- Download URL: pyorganoid-0.1.4-py3-none-any.whl
- Upload date:
- Size: 24.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.11.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | df659a2c46e83b394302a6c5565c32a68c322aac5878c234bd36903acc030a51 |
|
MD5 | d1a72a456ebd6215a876fdd77d1e4d37 |
|
BLAKE2b-256 | 2deb4aefa9304ad3aa60c853f785adc09855d1e8830ad3abd43240411d086d30 |