Coder Social home page Coder Social logo

eegkit / nwbwidgets Goto Github PK

View Code? Open in Web Editor NEW

This project forked from neurodatawithoutborders/nwbwidgets

0.0 0.0 0.0 15.04 MB

Explore the hierarchical structure of NWB 2.0 files and visualize data with Jupyter widgets.

Home Page: https://nwb-widgets.readthedocs.io/en/latest/

License: Other

Shell 0.07% Python 99.09% Jupyter Notebook 0.58% Dockerfile 0.26%

nwbwidgets's Introduction

PyPI version codecov License Binder

NWB Widgets

Explore NWB data in Jupyter

Explore our documentation »

Table of Contents

About

A library of widgets for visualization NWB data in a Jupyter notebook (or lab). The widgets allow you to navigate through the hierarchical structure of the NWB file and visualize specific data elements. It is designed to work out-of-the-box with NWB 2.0 files and to be easy to extend.

Installation

nwbwidgets requires Python >= 3.7.

The latest published version can be installed by running:

pip install nwbwidgets

Note that there are some optional dependencies required for some widgets. If an NWB data file contains a data type that requires additional dependencies, you will see a list of extra modules needed for that specific widget. All other widgets in the file will still work.

Usage

Using Panel

The easiest way to use NWB widgets is with the interactive Panel:

from nwbwidgets.panel import Panel

Panel()

Using nwb2widget

If you’re working directly with a NWB file object in your Jupyter notebook, you can also explore it with NWB Widgets using

from pynwb import NWBHDF5IO
from nwbwidgets import nwb2widget

io = NWBHDF5IO('path/to/file.nwb', mode='r')
nwb = io.read()

nwb2widget(nwb)

Using Docker

You can also run the NWB Widgets Panel using Docker:

$ docker run -p 8866:8866 ghcr.io/NeurodataWithoutBorders/nwbwidgets-panel:latest

Demo

Documentation

See our ReadTheDocs page for full documentation, including a gallery of all supported formats.

How it works

All visualizations are controlled by the dictionary neurodata_vis_spec. The keys of this dictionary are pynwb neurodata types, and the values are functions that take as input that neurodata_type and output a visualization. The visualizations may be of type Widget or matplotlib.Figure. When you enter a neurodata_type instance into nwb2widget, it searches the neurodata_vis_spec for that instance's neurodata_type, progressing backwards through the parent classes of the neurodata_type to find the most specific neurodata_type in neurodata_vis_spec. Some of these types are containers for other types, and create accordian UI elements for its contents, which are then passed into the neurodata_vis_spec and rendered accordingly.

Instead of supplying a function for the value of the neurodata_vis_spec dict, you may provide a dict or OrderedDict with string keys and function values. In this case, a tab structure is rendered, with each of the key/value pairs as an individual tab. All accordian and tab structures are rendered lazily- they are only called with that tab is selected. As a result, you can provide may tabs for a single data type without a worry. They will only be run if they are selected.

Extending

To extend NWBWidgets, all you need to a function that takes as input an instance of a specific neurodata_type class, and outputs a matplotlib figure or a jupyter widget.

Used in

nwbwidgets's People

Contributors

bendichter avatar luiztauffer avatar codycbakerphd avatar armin12 avatar tomdonoghue avatar pre-commit-ci[bot] avatar saksham20 avatar thewtex avatar h-mayorquin avatar abbydichter avatar nilegraddis avatar magland avatar bjhardcastle avatar alejoe91 avatar mrscheid avatar rly avatar d-sot avatar ajtritt avatar brianhhu avatar davclark avatar nicain avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.