-
Notifications
You must be signed in to change notification settings - Fork 48
MAJOR REFACTOR: remove extra modules of imaging #198
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Merged
Merged
Changes from 1 commit
Commits
Show all changes
8 commits
Select commit
Hold shift + click to select a range
4f0c53e
Remove extra modules & update Element to account for deletions
kushalbakshi 4930c59
Update CaImAn requirement list to datajoint fork
kushalbakshi a90eb2d
Update element_calcium_imaging/__init__.py
kushalbakshi 4aa4112
Merge branch 'main' of https://github.com/datajoint/element-calcium-i…
kushalbakshi b4360de
Update version and CHANGELOG
kushalbakshi 7bcd503
Remove python 3.7 and 3.8 from style test GHA workflow
kushalbakshi 467bfb7
Apply black formatting
kushalbakshi c85c7ce
Update test GHA
kushalbakshi File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -1,32 +1,34 @@ | ||
| # DataJoint Element for Functional Calcium Imaging | ||
|
|
||
| DataJoint Element for functional calcium imaging with | ||
| [ScanImage](https://docs.scanimage.org/), | ||
| [Scanbox](https://scanbox.org/), | ||
| [Nikon NIS-Elements](https://www.microscope.healthcare.nikon.com/products/software/nis-elements), | ||
| and `Bruker Prairie View` acquisition software; and | ||
| [Suite2p](https://github.com/MouseLand/suite2p), | ||
| DataJoint Element for functional calcium imaging with support for | ||
| [ScanImage](https://docs.scanimage.org/), [Scanbox](https://scanbox.org/), [Nikon | ||
| NIS-Elements](https://www.microscope.healthcare.nikon.com/products/software/nis-elements), | ||
| and `Bruker Prairie View` acquisition software; and | ||
| [Suite2p](https://github.com/MouseLand/suite2p), | ||
| [CaImAn](https://github.com/flatironinstitute/CaImAn), and | ||
| [EXTRACT](https://github.com/schnitzer-lab/EXTRACT-public) analysis | ||
| software. DataJoint Elements collectively standardize and automate | ||
| data collection and analysis for neuroscience experiments. Each Element is a modular | ||
| pipeline for data storage and processing with corresponding database tables that can be | ||
| combined with other Elements to assemble a fully functional pipeline. This repository | ||
| also provides a tutorial environment and notebooks to learn the pipeline. | ||
| [EXTRACT](https://github.com/schnitzer-lab/EXTRACT-public) analysis software. DataJoint | ||
| Elements collectively standardize and automate data collection and analysis for | ||
| neuroscience experiments. Each Element is a modular pipeline for data storage and | ||
| processing with corresponding database tables that can be combined with other Elements | ||
| to assemble a fully functional pipeline. This repository also provides a tutorial | ||
| environment and notebooks to learn the pipeline. | ||
|
|
||
| ## Experiment Flowchart | ||
|
|
||
|  | ||
|
|
||
| ## Data Pipeline Diagram | ||
|
|
||
|  | ||
|  | ||
|
|
||
| + We have designed three variations of the pipeline to handle different use cases. | ||
| Displayed above is the default `imaging` schema. Details on all of the `imaging` | ||
| schemas can be found in the [Data | ||
| Pipeline](https://datajoint.com/docs/elements/element-calcium-imaging/latest/pipeline/) | ||
| documentation page. | ||
| ### Legacy Support | ||
|
|
||
| + Three variations of the pipeline were designed and supported through December 2024 to | ||
| handle different use cases. However, based on community feedback and use cases, only | ||
| one pipeline will be supported after December 2024. However, all three pipeline | ||
| versions will remain available in their own branches for reference and use. | ||
| + Displayed above is the default `imaging` schema. Please see other branches for the | ||
| `imaging` module with `Curation` table and the `imaging_preprocess` module. | ||
|
|
||
| ## Getting Started | ||
|
|
||
|
|
@@ -55,37 +57,64 @@ or contact our team by email at [email protected]. | |
|
|
||
| ## Interactive Tutorial | ||
|
|
||
| + The easiest way to learn about DataJoint Elements is to use the tutorial notebooks within the included interactive environment configured using [Dev Container](https://containers.dev/). | ||
| + The easiest way to learn about DataJoint Elements is to use the tutorial notebooks | ||
| within the included interactive environment configured using [Dev | ||
| Container](https://containers.dev/). | ||
|
|
||
| ### Launch Environment | ||
|
|
||
| Here are some options that provide a great experience: | ||
|
|
||
| - (*recommended*) Cloud-based Environment | ||
| - Launch using [GitHub Codespaces](https://github.com/features/codespaces) using the `+` option which will `Create codespace on main` in the codebase repository on your fork with default options. For more control, see the `...` where you may create `New with options...`. | ||
| - Build time for a codespace is a few minutes. This is done infrequently and cached for convenience. | ||
| - Start time for a codespace is less than 1 minute. This will pull the built codespace from cache when you need it. | ||
| - *Tip*: Each month, GitHub renews a [free-tier](https://docs.github.com/en/billing/managing-billing-for-github-codespaces/about-billing-for-github-codespaces#monthly-included-storage-and-core-hours-for-personal-accounts) quota of compute and storage. Typically we run into the storage limits before anything else since Codespaces consume storage while stopped. It is best to delete Codespaces when not actively in use and recreate when needed. We'll soon be creating prebuilds to avoid larger build times. Once any portion of your quota is reached, you will need to wait for it to be reset at the end of your cycle or add billing info to your GitHub account to handle overages. | ||
| - *Tip*: GitHub auto names the codespace but you can rename the codespace so that it is easier to identify later. | ||
|
|
||
| - Local Environment | ||
| > *Note: Access to example data is currently limited to MacOS and Linux due to the s3fs utility. Windows users are recommended to use the above environment.* | ||
| - Install [Git](https://git-scm.com/book/en/v2/Getting-Started-Installing-Git) | ||
| - Install [Docker](https://docs.docker.com/get-docker/) | ||
| - Install [VSCode](https://code.visualstudio.com/) | ||
| - Install the VSCode [Dev Containers extension](https://marketplace.visualstudio.com/items?itemName=ms-vscode-remote.remote-containers) | ||
| - `git clone` the codebase repository and open it in VSCode | ||
| - Use the `Dev Containers extension` to `Reopen in Container` (More info is in the `Getting started` included with the extension.) | ||
|
|
||
| You will know your environment has finished loading once you either see a terminal open related to `Running postStartCommand` with a final message of `Done` or the `README.md` is opened in `Preview`. | ||
| + (*recommended*) Cloud-based Environment | ||
| + Launch using [GitHub Codespaces](https://github.com/features/codespaces) using the | ||
| `+` option which will `Create codespace on main` in the codebase repository on your | ||
| fork with default options. For more control, see the `...` where you may create `New | ||
| with options...`. | ||
| + Build time for a codespace is a few minutes. This is done infrequently and cached | ||
| for convenience. | ||
| + Start time for a codespace is less than 1 minute. This will pull the built codespace | ||
| from cache when you need it. | ||
| + *Tip*: Each month, GitHub renews a | ||
| [free-tier](https://docs.github.com/en/billing/managing-billing-for-github-codespaces/about-billing-for-github-codespaces#monthly-included-storage-and-core-hours-for-personal-accounts) | ||
| quota of compute and storage. Typically we run into the storage limits before | ||
| anything else since Codespaces consume storage while stopped. It is best to delete | ||
| Codespaces when not actively in use and recreate when needed. We'll soon be creating | ||
| prebuilds to avoid larger build times. Once any portion of your quota is reached, | ||
| you will need to wait for it to be reset at the end of your cycle or add billing | ||
| info to your GitHub account to handle overages. | ||
| + *Tip*: GitHub auto names the codespace but you can rename the codespace so that it | ||
| is easier to identify later. | ||
|
|
||
| + Local Environment | ||
| > *Note: Access to example data is currently limited to MacOS and Linux due to the | ||
| > s3fs utility. Windows users are recommended to use the above environment.* | ||
| + Install [Git](https://git-scm.com/book/en/v2/Getting-Started-Installing-Git) | ||
| + Install [Docker](https://docs.docker.com/get-docker/) | ||
| + Install [VSCode](https://code.visualstudio.com/) | ||
| + Install the VSCode [Dev Containers | ||
| extension](https://marketplace.visualstudio.com/items?itemName=ms-vscode-remote.remote-containers) | ||
| + `git clone` the codebase repository and open it in VSCode | ||
| + Use the `Dev Containers extension` to `Reopen in Container` (More info is in the | ||
| `Getting started` included with the extension.) | ||
|
|
||
| You will know your environment has finished loading once you either see a terminal open | ||
| related to `Running postStartCommand` with a final message of `Done` or the `README.md` | ||
| is opened in `Preview`. | ||
|
|
||
| Once the environment has launched, please run the following command in the terminal: | ||
| ``` | ||
| ```sh | ||
| MYSQL_VER=8.0 docker compose -f docker-compose-db.yaml up --build -d | ||
| ``` | ||
|
|
||
| ### Instructions | ||
|
|
||
| 1. We recommend you start by navigating to the `notebooks` directory on the left panel and go through the `tutorial.ipynb` Jupyter notebook. Execute the cells in the notebook to begin your walk through of the tutorial. | ||
| 1. We recommend you start by navigating to the `notebooks` directory on the left panel | ||
| and go through the `tutorial.ipynb` Jupyter notebook. Execute the cells in the | ||
| notebook to begin your walk through of the tutorial. | ||
|
|
||
| 1. Once you are done, see the options available to you in the menu in the bottom-left corner. For example, in Codespace you will have an option to `Stop Current Codespace` but when running Dev Container on your own machine the equivalent option is `Reopen folder locally`. By default, GitHub will also automatically stop the Codespace after 30 minutes of inactivity. Once the Codespace is no longer being used, we recommend deleting the Codespace. | ||
| 2. Once you are done, see the options available to you in the menu in the bottom-left | ||
| corner. For example, in Codespace you will have an option to `Stop Current Codespace` | ||
| but when running Dev Container on your own machine the equivalent option is `Reopen | ||
| folder locally`. By default, GitHub will also automatically stop the Codespace after | ||
| 30 minutes of inactivity. Once the Codespace is no longer being used, we recommend | ||
| deleting the Codespace. | ||
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,3 @@ | ||
| from . import imaging | ||
|
|
||
| imaging_no_curation = imaging | ||
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Uh oh!
There was an error while loading. Please reload this page.