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

Rc/2.16.0 #2722

Merged
merged 95 commits into from
Nov 9, 2023
Merged
Changes from 3 commits
Commits
Show all changes
95 commits
Select commit Hold shift + click to select a range
91456bf
Add new nwb writers with metadata comparison.
morriscb Jan 19, 2023
47b14c6
Add session_type and project code parsing.
morriscb Feb 15, 2023
9ed214a
isort+black
morriscb Mar 15, 2023
c9ced58
Add stimulus_block_name column to stimulus_presentations.
morriscb Feb 28, 2023
394265b
Add trials_id creation to BehaviorSession.from_lims
morriscb Mar 22, 2023
71d98ca
isort+black
morriscb Mar 31, 2023
1ef1c85
Changes to support python 3.10
aamster Mar 31, 2023
4973c33
update setup
aamster Mar 31, 2023
6e664d7
remove upper bound on matplotlib
aamster Mar 31, 2023
627b028
Revert "allow manually running nightly"
aamster Mar 31, 2023
af046ae
set seed for df.sample
mikejhuang Mar 31, 2023
4263a89
Clean up NWB creation code.
morriscb Mar 31, 2023
4afd032
isort+black
morriscb Apr 4, 2023
61eb2b0
read session_type from db
aamster Apr 6, 2023
8cc18e1
remove logic that read session_type and daq from vbn code path
aamster Apr 6, 2023
5190992
read date of acquisition from lims
aamster Apr 6, 2023
4d07bb4
remove unused import
aamster Apr 6, 2023
b662c9c
lint
aamster Apr 6, 2023
ee98346
ignore column order in test
aamster Apr 6, 2023
80d16d8
revert left join on ophys containers
aamster Apr 6, 2023
e185833
abstracts out logic to merge columns
aamster Apr 7, 2023
640ae73
fix bug due to duplicated project_code logic
aamster Apr 7, 2023
8da875a
Update behavior metadata writer.
morriscb Apr 4, 2023
f718c57
flip input axes to _gaussian_function_2d to conform to np.array
mikejhuang Apr 21, 2023
82f6fcd
lint
mikejhuang Apr 21, 2023
7148ac8
isort+black+manual comment line length editing receptive_field_mapping
mikejhuang Apr 22, 2023
fc126ea
Updating images to use PIL Image
Ahad-Allen May 5, 2023
d9893a0
Add negative running speed check.
morriscb Mar 15, 2023
55eb2b9
Clean up for VBO update release
morriscb Apr 18, 2023
9defb58
Implement fixes to presentations table.
morriscb Jun 2, 2023
04506b3
Add new information to templates data.
morriscb Jun 14, 2023
00b4e98
Add stimulus template for movies.
morriscb Jun 20, 2023
5d7bd78
load probe lfp metadata without needing to load lfp
aamster Jul 13, 2023
005e680
Add removal of omitted stimulus to presentations.
morriscb Jul 17, 2023
e271391
Unpeg statsmodels
morriscb Jul 18, 2023
f6942c0
Check for non-zero df length.
morriscb Jul 19, 2023
6e0647b
isort+black
morriscb Jul 20, 2023
2a15fae
set structure_id to primary_injection_structure instead of first stru…
mikejhuang Jul 19, 2023
27e48f7
lint
mikejhuang Jul 24, 2023
64943f0
lint
mikejhuang Jul 24, 2023
b8e4882
Fix for namespaces issue
brendanjohnharris Aug 9, 2023
3076275
fix deprecated np.bool
mikejhuang Jul 21, 2023
745d668
fix Int64Index deprecation and explicit requirement for regex boolean…
mikejhuang Jul 21, 2023
f89538a
fix pandas reindex change
mikejhuang Jul 21, 2023
b2f540d
change check_less_precise to rtol in assert_series_equal
mikejhuang Jul 24, 2023
ad6c339
fix attempt to reindex a MultiIndex
mikejhuang Jul 24, 2023
a77531f
fix deprecated np.float and np.int
mikejhuang Jul 24, 2023
a951f09
downgrade pandas=1.53, hdmf=3.4.7, pynwb=2.3.3
mikejhuang Jul 24, 2023
d311a5e
add python 3.11 to github actions
mikejhuang Jul 24, 2023
0f714ec
add Python 3.11 in setup.py
mikejhuang Jul 24, 2023
4e65a29
remove poetry related setup config
mikejhuang Aug 10, 2023
64e334f
Updates before VBO re-release
morriscb Jul 25, 2023
7af2406
Merge branch 'ticket/PSB-171/dev' into rc/2.16.0
morriscb Aug 11, 2023
26a4665
change bool_ to bool
mikejhuang Aug 11, 2023
e768fcc
Merge pull request #2716 from AllenInstitute/psb-172/update_dependenc…
mikejhuang Aug 14, 2023
163414e
Add additional column for quality value in units.csv.
morriscb Aug 3, 2023
2c9dc0c
Fix linting on failing files updated in previous commit.
morriscb Aug 17, 2023
a3aa0cf
Merge branch 'ticket/PSB-167/addQualityToMetadataTable' into rc/2.16.0
morriscb Aug 21, 2023
b950704
Add is_sham_change column.
morriscb Aug 9, 2023
584144c
isort+black
morriscb Aug 21, 2023
420d6e2
Merge branch 'ticket/PSB-155/dev' into rc/2.16.0
morriscb Aug 21, 2023
e0aa7e3
Merge pull request #2714 from brendanjohnharris/namespace-fix
morriscb Sep 8, 2023
f952b32
unpin hdmf and pynwb
mikejhuang Sep 8, 2023
0b3d496
exclude failed version ranges from hdmf
mikejhuang Sep 8, 2023
deab76b
Merge pull request #2720 from AllenInstitute/unpin_hdmf_and_pynwb
mikejhuang Sep 8, 2023
9052d0d
Increment version.
morriscb Sep 11, 2023
2e58703
Clean up code and add info to change log/release notes.
morriscb Sep 12, 2023
22106c4
Merge branch 'ticket/PSB-200/dev' into rc/2.16.0
morriscb Sep 26, 2023
cb5c52a
Add fixes to notebooks.
morriscb Sep 27, 2023
dccacd9
Update notebooks
morriscb Sep 27, 2023
715f728
Revert to json for vbn packaging.
morriscb Sep 25, 2023
d0c44bc
Merge branch 'ticket/PSB-227/dev' into rc/2.16.0
morriscb Sep 28, 2023
50fa924
Add timezone to behavior session table daq.
morriscb Sep 28, 2023
8eb86aa
Merge branch 'ticket/PSB-235/dev' into rc/2.16.0
morriscb Oct 6, 2023
c6202e6
Add natural movie cache class.
morriscb Oct 4, 2023
ecae373
Merge branch 'ticket/PSB-207/dev' into rc/2.16.0
morriscb Oct 12, 2023
3df4687
Explicitly set xarray coordinates.
morriscb Oct 25, 2023
fe87c87
Merge branch 'ticket/PSB-257/dev' into rc/2.16.0
morriscb Oct 25, 2023
f1ae5ab
Address comments on release from Marina
morriscb Oct 17, 2023
0620446
isort+black
morriscb Nov 1, 2023
f8ea31b
Merge branch 'ticket/PSB-249/dev' into rc/2.16.0
morriscb Nov 1, 2023
03a784c
Remove skip and test lims consistency with new data.
morriscb Oct 25, 2023
fd138ea
Add section to vbo sphinx page.
morriscb Nov 3, 2023
6fe632e
isort+black
morriscb Nov 3, 2023
77737ec
Update more docs
morriscb Nov 3, 2023
5a66e26
Merge branch 'ticket/PSB-7/dev' into rc/2.16.0
morriscb Nov 3, 2023
1c51e73
Modify notebooks to use stimulus presentations.
morriscb Nov 3, 2023
18c5340
Debug notebook.
morriscb Nov 3, 2023
4b497ed
Fix type for pandas query.
morriscb Nov 6, 2023
387a0bc
Add comment.
morriscb Nov 6, 2023
9b3b52d
Update notebooks
morriscb Nov 6, 2023
5337446
Update where cache points.
morriscb Nov 8, 2023
9b17c6d
Add doc on traces.
morriscb Nov 8, 2023
b53471f
Clarify trace change log comment.
morriscb Nov 8, 2023
1454801
Update changelog and index.
morriscb Nov 9, 2023
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
Original file line number Diff line number Diff line change
@@ -1,28 +1,39 @@
from typing import Optional, List, Union
import warnings
from pathlib import Path
import pandas as pd
import numpy as np
from typing import List, Optional, Union

import numpy as np
import pandas as pd
from allensdk.api.warehouse_cache.cache import Cache
from allensdk.brain_observatory.behavior.behavior_ophys_experiment import \
BehaviorOphysExperiment
from allensdk.brain_observatory.behavior.behavior_project_cache.tables \
.experiments_table import \
ExperimentsTable
from allensdk.brain_observatory.behavior.behavior_project_cache.tables \
.sessions_table import \
SessionsTable
from allensdk.api.warehouse_cache.caching_utilities import (
one_file_call_caching,
)
from allensdk.brain_observatory.behavior.behavior_ophys_experiment import (
BehaviorOphysExperiment,
)
from allensdk.brain_observatory.behavior.behavior_project_cache.project_apis.data_io import ( # noqa: E501
BehaviorProjectLimsApi, BehaviorProjectCloudApi)
from allensdk.api.warehouse_cache.caching_utilities import \
one_file_call_caching
from allensdk.brain_observatory.behavior.behavior_project_cache.tables \
.ophys_sessions_table import \
BehaviorOphysSessionsTable
from allensdk.brain_observatory.behavior.behavior_session import \
BehaviorSession
from allensdk.brain_observatory.behavior.behavior_project_cache \
.project_cache_base import ProjectCacheBase
BehaviorProjectCloudApi,
BehaviorProjectLimsApi,
)
from allensdk.brain_observatory.behavior.behavior_project_cache.project_cache_base import ( # noqa: E501
ProjectCacheBase,
)
from allensdk.brain_observatory.behavior.behavior_project_cache.tables.experiments_table import ( # noqa: E501
ExperimentsTable,
)
from allensdk.brain_observatory.behavior.behavior_project_cache.tables.ophys_sessions_table import ( # noqa: E501
BehaviorOphysSessionsTable,
)
from allensdk.brain_observatory.behavior.behavior_project_cache.tables.sessions_table import ( # noqa: E501
SessionsTable,
)
from allensdk.brain_observatory.behavior.behavior_session import (
BehaviorSession,
)


class UpdatedStimulusPresentationTableWarning(UserWarning):
pass


class VBOLimsCache(Cache):
@@ -41,41 +52,41 @@ class VBOLimsCache(Cache):
OPHYS_SESSIONS_KEY: {
"spec": f"{OPHYS_SESSIONS_KEY}.csv",
"parent_key": "BASEDIR",
"typename": "file"
"typename": "file",
},
BEHAVIOR_SESSIONS_KEY: {
"spec": f"{BEHAVIOR_SESSIONS_KEY}.csv",
"parent_key": "BASEDIR",
"typename": "file"
"typename": "file",
},
OPHYS_EXPERIMENTS_KEY: {
"spec": f"{OPHYS_EXPERIMENTS_KEY}.csv",
"parent_key": "BASEDIR",
"typename": "file"
"typename": "file",
},
OPHYS_CELLS_KEY: {
"spec": f"{OPHYS_CELLS_KEY}.csv",
"parent_key": "BASEDIR",
"typename": "file"
}
"typename": "file",
},
}


class VisualBehaviorOphysProjectCache(ProjectCacheBase):

PROJECT_NAME = "visual-behavior-ophys"
BUCKET_NAME = "visual-behavior-ophys-data"
BUCKET_NAME = "staging.visual-behavior-ophys-data"

def __init__(
self,
fetch_api: Optional[Union[BehaviorProjectLimsApi,
BehaviorProjectCloudApi]] = None,
fetch_tries: int = 2,
manifest: Optional[Union[str, Path]] = None,
version: Optional[str] = None,
cache: bool = True
self,
fetch_api: Optional[
Union[BehaviorProjectLimsApi, BehaviorProjectCloudApi]
] = None,
fetch_tries: int = 2,
manifest: Optional[Union[str, Path]] = None,
version: Optional[str] = None,
cache: bool = True,
):
""" Entrypoint for accessing visual behavior data. Supports
"""Entrypoint for accessing visual behavior data. Supports
access to summaries of session data and provides tools for
downloading detailed session data (such as dff traces).
@@ -117,9 +128,26 @@ def __init__(

if not isinstance(self.fetch_api, BehaviorProjectCloudApi):
if cache:
self.cache = VBOLimsCache(manifest=manifest_,
version=version,
cache=cache)
self.cache = VBOLimsCache(
manifest=manifest_, version=version, cache=cache
)

warnings.warn(
message="\n\tAs of AllenSDK version 2.16.0, the latest Visual "
"Behavior Ophys data has been significantly updated from "
"previous releases. Specifically the user will need to "
"update all processing of the stimulus_presentations "
"tables. These tables now include multiple stimulus types "
"delineated by the columns `stimulus_block` and "
"`stimulus_block_name`.\n\nThe data that was available in "
"previous releases are stored in the "
"block name containing 'change_detection' and can be "
"accessed in the pandas table by using: \n\t"
"`stimulus_presentations["
"stimulus_presentations.stimulus_block_name.str.contains"
"('change_detection')]`",
category=UpdatedStimulusPresentationTableWarning,
)

@classmethod
def cloud_api_class(cls):
@@ -130,11 +158,11 @@ def lims_api_class(cls):
return BehaviorProjectLimsApi

def get_ophys_session_table(
self,
suppress: Optional[List[str]] = None,
index_column: str = "ophys_session_id",
as_df=True,
include_behavior_data=True
self,
suppress: Optional[List[str]] = None,
index_column: str = "ophys_session_id",
as_df=True,
include_behavior_data=True,
) -> Union[pd.DataFrame, BehaviorOphysSessionsTable]:
"""
Return summary table of all ophys_session_ids in the database.
@@ -155,13 +183,15 @@ def get_ophys_session_table(
if isinstance(self.fetch_api, BehaviorProjectCloudApi):
return self.fetch_api.get_ophys_session_table()
if self.cache is not None:
path = self.cache.get_cache_path(None,
self.cache.OPHYS_SESSIONS_KEY)
path = self.cache.get_cache_path(
None, self.cache.OPHYS_SESSIONS_KEY
)
ophys_sessions = one_file_call_caching(
path,
self.fetch_api.get_ophys_session_table,
_write_json,
lambda path: _read_json(path, index_name='ophys_session_id'))
lambda path: _read_json(path, index_name="ophys_session_id"),
)
else:
ophys_sessions = self.fetch_api.get_ophys_session_table()

@@ -171,24 +201,23 @@ def get_ophys_session_table(
suppress=suppress,
as_df=True,
include_ophys_data=False,
include_trial_metrics=False
include_trial_metrics=False,
)
ophys_sessions = behavior_sessions_table.merge(
ophys_sessions,
left_index=True,
right_on='behavior_session_id',
suffixes=('_behavior', '_ophys'))
right_on="behavior_session_id",
suffixes=("_behavior", "_ophys"),
)

sessions = BehaviorOphysSessionsTable(df=ophys_sessions,
suppress=suppress,
index_column=index_column)
sessions = BehaviorOphysSessionsTable(
df=ophys_sessions, suppress=suppress, index_column=index_column
)

return sessions.table if as_df else sessions

def get_ophys_experiment_table(
self,
suppress: Optional[List[str]] = None,
as_df=True
self, suppress: Optional[List[str]] = None, as_df=True
) -> Union[pd.DataFrame, SessionsTable]:
"""
Return summary table of all ophys_experiment_ids in the database.
@@ -201,27 +230,34 @@ def get_ophys_experiment_table(
if isinstance(self.fetch_api, BehaviorProjectCloudApi):
return self.fetch_api.get_ophys_experiment_table()
if self.cache is not None:
path = self.cache.get_cache_path(None,
self.cache.OPHYS_EXPERIMENTS_KEY)
path = self.cache.get_cache_path(
None, self.cache.OPHYS_EXPERIMENTS_KEY
)
experiments = one_file_call_caching(
path,
self.fetch_api.get_ophys_experiment_table,
_write_json,
lambda path: _read_json(path,
index_name='ophys_experiment_id'))
lambda path: _read_json(
path, index_name="ophys_experiment_id"
),
)
else:
experiments = self.fetch_api.get_ophys_experiment_table()

# Merge behavior data in
behavior_sessions_table = self.get_behavior_session_table(
suppress=suppress, as_df=True, include_ophys_data=False,
include_trial_metrics=False
suppress=suppress,
as_df=True,
include_ophys_data=False,
include_trial_metrics=False,
)
experiments = behavior_sessions_table.merge(
experiments, left_index=True, right_on='behavior_session_id',
suffixes=('_behavior', '_ophys'))
experiments = ExperimentsTable(df=experiments,
suppress=suppress)
experiments,
left_index=True,
right_on="behavior_session_id",
suffixes=("_behavior", "_ophys"),
)
experiments = ExperimentsTable(df=experiments, suppress=suppress)
return experiments.table if as_df else experiments

def get_ophys_cells_table(self) -> pd.DataFrame:
@@ -232,25 +268,24 @@ def get_ophys_cells_table(self) -> pd.DataFrame:
if isinstance(self.fetch_api, BehaviorProjectCloudApi):
return self.fetch_api.get_ophys_cells_table()
if self.cache is not None:
path = self.cache.get_cache_path(None,
self.cache.OPHyS_CELLS_KEY)
path = self.cache.get_cache_path(None, self.cache.OPHyS_CELLS_KEY)
ophys_cells_table = one_file_call_caching(
path,
self.fetch_api.get_ophys_cells_table,
_write_json,
lambda path: _read_json(path,
index_name='cell_roi_id'))
lambda path: _read_json(path, index_name="cell_roi_id"),
)
else:
ophys_cells_table = self.fetch_api.get_ophys_cells_table()

return ophys_cells_table

def get_behavior_session_table(
self,
suppress: Optional[List[str]] = None,
as_df=True,
include_ophys_data=True,
include_trial_metrics: bool = False
self,
suppress: Optional[List[str]] = None,
as_df=True,
include_ophys_data=True,
include_trial_metrics: bool = False,
) -> Union[pd.DataFrame, SessionsTable]:
"""
Return summary table of all behavior_session_ids in the database.
@@ -269,22 +304,23 @@ def get_behavior_session_table(
if isinstance(self.fetch_api, BehaviorProjectCloudApi):
return self.fetch_api.get_behavior_session_table()
if self.cache is not None:
path = self.cache.get_cache_path(None,
self.cache.BEHAVIOR_SESSIONS_KEY)
path = self.cache.get_cache_path(
None, self.cache.BEHAVIOR_SESSIONS_KEY
)
sessions = one_file_call_caching(
path,
self.fetch_api.get_behavior_session_table,
_write_json,
lambda path: _read_json(path,
index_name='behavior_session_id'))
lambda path: _read_json(
path, index_name="behavior_session_id"
),
)
else:
sessions = self.fetch_api.get_behavior_session_table()

if include_ophys_data:
ophys_session_table = self.get_ophys_session_table(
suppress=suppress,
as_df=False,
include_behavior_data=False
suppress=suppress, as_df=False, include_behavior_data=False
)
else:
ophys_session_table = None
@@ -293,12 +329,13 @@ def get_behavior_session_table(
suppress=suppress,
fetch_api=self.fetch_api,
ophys_session_table=ophys_session_table,
include_trial_metrics=include_trial_metrics)
include_trial_metrics=include_trial_metrics,
)

return sessions.table if as_df else sessions

def get_behavior_ophys_experiment(
self, ophys_experiment_id: int
self, ophys_experiment_id: int
) -> BehaviorOphysExperiment:
"""
Gets `BehaviorOphysExperiment` for `ophys_experiment_id`
@@ -311,11 +348,11 @@ def get_behavior_ophys_experiment(
BehaviorOphysExperiment
"""
return self.fetch_api.get_behavior_ophys_experiment(
ophys_experiment_id=ophys_experiment_id)
ophys_experiment_id=ophys_experiment_id
)

def get_behavior_session(
self,
behavior_session_id: int
self, behavior_session_id: int
) -> BehaviorSession:
"""
Gets `BehaviorSession` for `behavior_session_id`
@@ -346,7 +383,7 @@ def get_natural_movie_template(self, n_workers=None) -> pd.DataFrame:
frames as presented to the mouse. The DataFrame is indexed with the
same frame index as shown in the stimulus presentation table.
The processing of the movie requires signicant processing and its
The processing of the movie requires significant processing and its
return size is very large so take care in requesting this data.
Parameters
@@ -381,8 +418,12 @@ def _write_json(path, df):

def _read_json(path, index_name: Optional[str] = None):
"""Reads a dataframe file written to the cache by _write_json."""
df = pd.read_json(path, date_unit="s", orient="split",
convert_dates=["date_of_acquisition"])
df = pd.read_json(
path,
date_unit="s",
orient="split",
convert_dates=["date_of_acquisition"],
)
if index_name:
df = df.rename_axis(index=index_name)
return df
Loading