Skip to content

Commit

Permalink
Add transform widget (#88)
Browse files Browse the repository at this point in the history
* Add transform widget

* Improve testing

* [pre-commit.ci] auto fixes from pre-commit.com hooks

for more information, see https://pre-commit.ci

* Update widget name and citation

* Add docstrings and typing

* remove ref to tooltips

* Add napari trove classifier

* Update widget name

* Remove unnecessary 1 line functions

* Remove parameter default

---------

Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
  • Loading branch information
adamltyson and pre-commit-ci[bot] authored Jul 31, 2024
1 parent 78533f8 commit 7098eb8
Show file tree
Hide file tree
Showing 14 changed files with 1,642 additions and 42 deletions.
19 changes: 8 additions & 11 deletions .github/workflows/test_and_deploy.yml
Original file line number Diff line number Diff line change
Expand Up @@ -26,9 +26,6 @@ jobs:
needs: [linting, manifest]
name: ${{ matrix.os }} py${{ matrix.python-version }}
runs-on: ${{ matrix.os }}
env:
# pooch cache dir
BRAINGLOBE_TEST_DATA_DIR: "~/.pooch_cache"

strategy:
matrix:
Expand All @@ -45,12 +42,13 @@ jobs:
python-version: "3.12"

steps:
- name: Cache pooch data
- name: Cache data
uses: actions/cache@v4
with:
path: "~/.pooch_cache"
path: "$HOME/.brainglobe"
# hash on conftest in case url changes
key: ${{ runner.os }}-${{ matrix.python-version }}-${{ hashFiles('**/conftest.py') }}
key: brainglobe-dir-${{ runner.os }}${{ hashFiles('**/conftest.py') }}


- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v4
Expand All @@ -72,16 +70,15 @@ jobs:
runs-on: ubuntu-latest
env:
NUMBA_DISABLE_JIT: "1"
# pooch cache dir
BRAINGLOBE_TEST_DATA_DIR: "~/.pooch_cache"


steps:
- name: Cache pooch data
- name: Cache data
uses: actions/cache@v4
with:
path: "~/.pooch_cache"
path: "$HOME/.brainglobe"
# hash on conftest in case url changes
key: ${{ runner.os }}-3.11-${{ hashFiles('**/conftest.py') }}
key: brainglobe-dir-${{ runner.os }}${{ hashFiles('**/conftest.py') }}

- name: Set up Python
uses: actions/setup-python@v4
Expand Down
1 change: 1 addition & 0 deletions MANIFEST.in
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ include LICENSE
include README.md

graft brainglobe_utils *.py
include brainglobe_utils/napari.yaml
include brainglobe_utils/qtpy/brainglobe.png

prune tests
47 changes: 22 additions & 25 deletions brainglobe_utils/brainmapper/analysis.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,10 @@
by Charly Rousseau (https://github.com/crousseau).
"""

import os
from dataclasses import dataclass
from pathlib import Path
from typing import List, Set, Union
from typing import List, Optional, Set, Union

import numpy as np
import pandas as pd
Expand Down Expand Up @@ -104,32 +105,23 @@ def combine_df_hemispheres(df: pd.DataFrame) -> pd.DataFrame:
return both


def create_all_cell_csv(
points: List[Point], output_filename: Union[str, Path]
) -> None:
def create_all_cell_df(points: List[Point]) -> None:
"""
Create a CSV file with cell data from a list of Point objects.
This function takes a list of Point objects, each representing cell
coordinates and brain region and converts this into a pandas DataFrame.
The DataFrame is then saved to a CSV file at the specified filename.
Parameters
----------
points : List[Point]
A list of Point objects, each containing cell data such as
raw and atlas coordinates,
structure name, and hemisphere information.
output_filename : Union[str, Path]
The filename (including path) where the CSV file will be saved.
Can be a string or a Path object.
Returns
-------
None
df: pd.DataFrame
"""

ensure_directory_exists(Path(output_filename).parent)
df = pd.DataFrame(
columns=(
"coordinate_raw_axis_0",
Expand All @@ -155,14 +147,13 @@ def create_all_cell_csv(
temp_matrix[i].append(point.hemisphere)

df = pd.DataFrame(temp_matrix, columns=df.columns, index=None)
df.to_csv(output_filename, index=False)
return df


def count_points_per_brain_region(
points: List[Point],
structures_with_points: Set[str],
brainreg_volume_csv_path: Union[str, Path],
output_filename: Union[str, Path],
) -> None:
"""
Count the number of points per brain region.
Expand All @@ -177,12 +168,11 @@ def count_points_per_brain_region(
brainreg_volume_csv_path : Union[str, Path]
The path to the CSV file containing volume information from the
brainreg registration.
output_filename : Union[str, Path]
The path where the summary of points by atlas region will be saved.
Returns
-------
None
df: pd.DataFrame
"""

structures_with_points = list(structures_with_points)
Expand Down Expand Up @@ -219,17 +209,16 @@ def count_points_per_brain_region(
combined_hemispheres = combine_df_hemispheres(sorted_point_numbers)
df = calculate_densities(combined_hemispheres, brainreg_volume_csv_path)
df = sanitise_df(df)

df.to_csv(output_filename, index=False)
return df


def summarise_points_by_atlas_region(
points_in_raw_data_space: np.ndarray,
points_in_atlas_space: np.ndarray,
atlas: BrainGlobeAtlas,
brainreg_volume_csv_path: Union[str, Path],
points_list_output_filename: Union[str, Path],
summary_filename: Union[str, Path],
brainreg_volume_csv_path: Optional[os.PathLike] = None,
points_list_output_filename: Optional[os.PathLike] = None,
summary_filename: Optional[os.PathLike] = None,
) -> None:
"""
Summarise points data by atlas region.
Expand Down Expand Up @@ -282,11 +271,19 @@ def summarise_points_by_atlas_region(
except Exception:
continue

create_all_cell_csv(points, points_list_output_filename)
all_cell_df = create_all_cell_df(points)

count_points_per_brain_region(
if points_list_output_filename is not None:
ensure_directory_exists(Path(points_list_output_filename).parent)
all_cell_df.to_csv(points_list_output_filename, index=False)

points_per_region_df = count_points_per_brain_region(
points,
structures_with_points,
brainreg_volume_csv_path,
summary_filename,
)

if summary_filename is not None:
points_per_region_df.to_csv(summary_filename, index=False)

return all_cell_df, points_per_region_df
Loading

0 comments on commit 7098eb8

Please sign in to comment.