Skip to content
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

Add transform widget #88

Merged
merged 10 commits into from
Jul 31, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
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
Loading