Skip to main content

Modeling tools for brain simulation.

Project description

Modeling tools for brain simulation

Header image of braintools.

Supported Python Version LICENSE Documentation Status PyPI version Continuous Integration Test Coverage DOI

braintools is a lightweight, JAX-friendly toolbox with practical utilities for brain modeling.

Highlights

  • Composable connectivity: declarative builders for point, multi-compartment, and population networks with spatial kernels, degree constraints, and unit-aware metadata
  • Cognitive task framework: phase-based, composable trial construction (braintools.cogtask) for training and analyzing neural networks on classic systems-neuroscience paradigms — decision making, working memory, reasoning, motor — plus a registry of pre-built tasks
  • Visualization suite: publication plots, interactive dashboards, 3D viewers, and animation helpers in braintools.visualize
  • Metrics and solvers: losses, evaluation metrics, and PyTree-aware ODE/SDE/DDE integrators ready for jit/vmap
  • Signal and optimization helpers: reusable generators and lightweight optimizers to prototype models quickly

braintools integrates smoothly with the broader ecosystem (e.g., brainstate, brainunit) while keeping a simple, functional style.

Installation

pip install -U braintools

Optional extras are published for hardware-specific builds:

pip install -U braintools[cpu]
# CUDA 12.x wheels
pip install -U braintools[cuda12]
# TPU runtime
pip install -U braintools[tpu]

Alternatively, install the curated BrainX bundle that ships with braintools and related projects:

pip install -U BrainX

Cognitive task framework (braintools.cogtask)

braintools.cogtask lets you build cognitive tasks from composable, named phases (fixation, stimulus, delay, response, ...) connected by simple operators:

  • a >> b runs b after a (sequential)
  • a * n repeats a n times
  • a | b runs a and b in parallel (multi-modal stimuli)
  • If, Switch, While add trial-by-trial branching

Trials are generated lazily via task.sample(i) / task.batch_sample(B), both JIT- and vmap-friendly, with per-trial keys derived from seed so batches are fully reproducible.

import brainunit as u
from braintools.cogtask import PerceptualDecisionMaking

task = PerceptualDecisionMaking(t_stimulus=1500 * u.ms, num_choices=2, seed=0)
X, Y = task.batch_sample(32)   # X: (T, B, n_in), Y: (T, B) labels

The package also ships a registry of canonical tasks: PerceptualDecisionMaking, ContextDecisionMaking, DelayMatchSample, DelayComparison, GoNoGo, ReadySetGo, PostDecisionWager, Reaching1D, EvidenceAccumulation, HierarchicalReasoning, and more — see the API reference for the full list.

Documentation

The full documentation is available at https://brainx.chaobrain.com/braintools/

Ecosystem

braintools is one part of our brain simulation ecosystem: https://brainx.chaobrain.com/

Contributing

Contributions and issue reports are welcome! See CONTRIBUTING.md for guidelines.

License

Apache 2.0. See LICENSE for details.

Citation

If you use braintools in your work, please cite the Zenodo DOI: 10.5281/zenodo.17110064

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

braintools-0.3.0.tar.gz (770.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

braintools-0.3.0-py3-none-any.whl (931.7 kB view details)

Uploaded Python 3

File details

Details for the file braintools-0.3.0.tar.gz.

File metadata

  • Download URL: braintools-0.3.0.tar.gz
  • Upload date:
  • Size: 770.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for braintools-0.3.0.tar.gz
Algorithm Hash digest
SHA256 8cb9f0ed3501b0ba5cc08f9643b0cf5455875aef8e4167b61824ed585342d873
MD5 04523d4df9e40b52797c520ad774a110
BLAKE2b-256 63d6c242a5d29d9f15551383cd7c29b2362d4162575beb79804d99c45f70603a

See more details on using hashes here.

File details

Details for the file braintools-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: braintools-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 931.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for braintools-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 7846be0329b9d1927d8d8ead899ca36aa45e9a6ea64ffd094125f159271d10cf
MD5 0c518d01b1b796f0bed8ef1f47a63f3f
BLAKE2b-256 74677e2ed918a71beb89a13b4471e87aeb9d41d573758c7bfd943534766615d3

See more details on using hashes here.

Supported by

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