-
Notifications
You must be signed in to change notification settings - Fork 35
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* First version of the template script * make example_mouse follow the new template * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * Fix error in example mouse * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * mixed up reference and annotation * added mandatory import to template * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * remove import from example * added mandatory import to template * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * include case where variables should be passed between functions * Update brainglobe_atlasapi/atlas_generation/atlas_scripts/example_mouse.py Co-authored-by: Alessandro Felder <[email protected]> * Update brainglobe_atlasapi/atlas_generation/atlas_scripts/template_script.py Co-authored-by: Alessandro Felder <[email protected]> * Update brainglobe_atlasapi/atlas_generation/atlas_scripts/template_script.py Co-authored-by: Alessandro Felder <[email protected]> * Update brainglobe_atlasapi/atlas_generation/atlas_scripts/template_script.py Co-authored-by: Alessandro Felder <[email protected]> * Update brainglobe_atlasapi/atlas_generation/atlas_scripts/example_mouse.py Co-authored-by: Alessandro Felder <[email protected]> * Update brainglobe_atlasapi/atlas_generation/atlas_scripts/example_mouse.py Co-authored-by: Alessandro Felder <[email protected]> * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * Update brainglobe_atlasapi/atlas_generation/atlas_scripts/template_script.py Co-authored-by: Alessandro Felder <[email protected]> * Update brainglobe_atlasapi/atlas_generation/atlas_scripts/template_script.py Co-authored-by: Alessandro Felder <[email protected]> * Update brainglobe_atlasapi/atlas_generation/atlas_scripts/template_script.py Co-authored-by: Alessandro Felder <[email protected]> * Update brainglobe_atlasapi/atlas_generation/atlas_scripts/template_script.py Co-authored-by: Alessandro Felder <[email protected]> * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * Update brainglobe_atlasapi/atlas_generation/atlas_scripts/example_mouse.py Co-authored-by: Alessandro Felder <[email protected]> * Update brainglobe_atlasapi/atlas_generation/atlas_scripts/example_mouse.py Co-authored-by: Alessandro Felder <[email protected]> * Update brainglobe_atlasapi/atlas_generation/atlas_scripts/example_mouse.py Co-authored-by: Alessandro Felder <[email protected]> * Update brainglobe_atlasapi/atlas_generation/atlas_scripts/template_script.py Co-authored-by: Alessandro Felder <[email protected]> * keep lines shorter than limit and only run code in __main__ * reformat example mouse * use pooch to validate hash * add bg_root_dir global * fix references to annotation and reference * fix error in the way structure id paths were shown in the example * fix typo * Update brainglobe_atlasapi/atlas_generation/atlas_scripts/example_mouse.py Co-authored-by: Alessandro Felder <[email protected]> * adjust comment suggestion to be compliant with the 79 character line limit * add additional reference to packaging template script --------- Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com> Co-authored-by: Alessandro Felder <[email protected]>
- Loading branch information
1 parent
299f495
commit e718f4c
Showing
2 changed files
with
284 additions
and
56 deletions.
There are no files selected for viewing
This file contains 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
158 changes: 158 additions & 0 deletions
158
brainglobe_atlasapi/atlas_generation/atlas_scripts/template_script.py
This file contains 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,158 @@ | ||
from pathlib import Path | ||
|
||
from brainglobe_atlasapi.atlas_generation.wrapup import wrapup_atlas_from_data | ||
|
||
# Copy-paste this script into a new file and fill in the functions to package | ||
# your own atlas. | ||
|
||
### Metadata ### | ||
|
||
# The minor version of the atlas in the brainglobe_atlasapi, this is internal, | ||
# if this is the first time this atlas has been added the value should be 0 | ||
# (minor version is the first number after the decimal point, ie the minor | ||
# version of 1.2 is 2) | ||
__version__ = 0 | ||
|
||
# The expected format is FirstAuthor_SpeciesCommonName, e.g. kleven_rat, or | ||
# Institution_SpeciesCommonName, e.g. allen_mouse. | ||
ATLAS_NAME = "example_mouse" | ||
|
||
# DOI of the most relevant citable document | ||
CITATION = None | ||
|
||
# The scientific name of the species, ie; Rattus norvegicus | ||
SPECIES = None | ||
|
||
# The URL for the data files | ||
ATLAS_LINK = None | ||
|
||
# The orientation of the **original** atlas data, in BrainGlobe convention: | ||
# https://brainglobe.info/documentation/setting-up/image-definition.html#orientation | ||
ORIENTATION = "asr" | ||
|
||
# The id of the highest level of the atlas. This is commonly called root or | ||
# brain. Include some information on what to do if your atlas is not | ||
# hierarchical | ||
ROOT_ID = None | ||
|
||
# The resolution of your volume in microns. Details on how to format this | ||
# parameter for non isotropic datasets or datasets with multiple resolutions. | ||
RESOLUTION = None | ||
|
||
|
||
def download_resources(): | ||
""" | ||
Download the necessary resources for the atlas. | ||
If possible, please use the Pooch library to retrieve any resources. | ||
""" | ||
pass | ||
|
||
|
||
def retrieve_reference_and_annotation(): | ||
""" | ||
Retrieve the desired reference and annotation as two numpy arrays. | ||
Returns: | ||
tuple: A tuple containing two numpy arrays. The first array is the | ||
reference volume, and the second array is the annotation volume. | ||
""" | ||
reference = None | ||
annotation = None | ||
return reference, annotation | ||
|
||
|
||
def retrieve_hemisphere_map(): | ||
""" | ||
Retrieve a hemisphere map for the atlas. | ||
If your atlas is asymmetrical, you may want to use a hemisphere map. | ||
This is an array in the same shape as your template, | ||
with 0's marking the left hemisphere, and 1's marking the right. | ||
If your atlas is symmetrical, ignore this function. | ||
Returns: | ||
numpy.array or None: A numpy array representing the hemisphere map, | ||
or None if the atlas is symmetrical. | ||
""" | ||
return None | ||
|
||
|
||
def retrieve_structure_information(): | ||
""" | ||
This function should return a pandas DataFrame with information about your | ||
atlas. | ||
The DataFrame should be in the following format: | ||
╭────┬───────────────────┬─────────┬───────────────────┬─────────────────╮ | ||
| id | name | acronym | structure_id_path | rgb_triplet | | ||
| | | | | | | ||
├────┼───────────────────┼─────────┼───────────────────┼─────────────────┤ | ||
| 997| root | root | [997] | [255, 255, 255] | | ||
├────┼───────────────────┼─────────┼───────────────────┼─────────────────┤ | ||
| 8 | Basic cell groups | grey | [997, 8] | [191, 218, 227] | | ||
├────┼───────────────────┼─────────┼───────────────────┼─────────────────┤ | ||
| 567| Cerebrum | CH | [997, 8, 567] | [176, 240, 255] | | ||
╰────┴───────────────────┴─────────┴───────────────────┴─────────────────╯ | ||
Returns: | ||
pandas.DataFrame: A DataFrame containing the atlas information. | ||
""" | ||
return None | ||
|
||
|
||
def retrieve_or_construct_meshes(): | ||
""" | ||
This function should return a dictionary of ids and corresponding paths to | ||
mesh files. Some atlases are packaged with mesh files, in these cases we | ||
should use these files. Then this function should download those meshes. | ||
In other cases we need to construct the meshes ourselves. For this we have | ||
helper functions to achieve this. | ||
""" | ||
meshes_dict = {} | ||
return meshes_dict | ||
|
||
|
||
def retrieve_additional_references(): | ||
"""This function only needs editing if the atlas has additional reference | ||
images. It should return a dictionary that maps the name of each | ||
additional reference image to an image stack containing its data. | ||
""" | ||
additional_references = {} | ||
return additional_references | ||
|
||
|
||
### If the code above this line has been filled correctly, nothing needs to be | ||
### edited below (unless variables need to be passed between the functions). | ||
if __name__ == "__main__": | ||
bg_root_dir = Path.home() / "brainglobe_workingdir" / ATLAS_NAME | ||
bg_root_dir.mkdir(exist_ok=True) | ||
download_resources() | ||
reference_volume, annotated_volume = retrieve_reference_and_annotation() | ||
additional_references = retrieve_additional_references() | ||
hemispheres_stack = retrieve_hemisphere_map() | ||
structures = retrieve_structure_information() | ||
meshes_dict = retrieve_or_construct_meshes() | ||
|
||
output_filename = wrapup_atlas_from_data( | ||
atlas_name=ATLAS_NAME, | ||
atlas_minor_version=__version__, | ||
citation=CITATION, | ||
atlas_link=ATLAS_LINK, | ||
species=SPECIES, | ||
resolution=(RESOLUTION,) * 3, | ||
orientation=ORIENTATION, | ||
root_id=ROOT_ID, | ||
reference_stack=reference_volume, | ||
annotation_stack=annotated_volume, | ||
structures_list=structures, | ||
meshes_dict=meshes_dict, | ||
working_dir=bg_root_dir, | ||
hemispheres_stack=None, | ||
cleanup_files=False, | ||
compress=True, | ||
scale_meshes=True, | ||
additional_references=additional_references, | ||
) |