/brain_observatory_qc

Primary LanguageJupyter NotebookOtherNOASSERTION

brain_observatory_qc

brain_observatory_qc is inteded to be both a standalone repo of quality control metrics and plots for Allen Brain Observatory projects that utilitze 2-photon imaging, and a central location for for tracking data quality issues related to ongoing Allen Brain Observatory projects.The repo is internally facing only.

Anyone with data quality concerns should log issues here to ensure that they are tracked and followed up on. This repository should be a central place to log and track issues, along with any associated documents (Jupyter Notebooks, PDF writeups, slide decks, etc.) that were prepared in the process of tracking or following up on issues.

Functions in this repository depend on the AllenSDK https://github.com/AllenInstitute/AllenSDK

Installation

Set up a dedicated conda environment:

conda create -n boqc python=3.8 

Activate the new environment:

conda activate boqc

Make the new environment visible in the Jupyter

pip install ipykernel
python -m ipykernel install --user --name boqc

Install brain_observatory_qc

git clone https://github.com/AllenInstitute/brain_observatory_qc.git
cd brain_observatory_qc
pip install -e .

Testing

Unit testing is required for new functions.

Tests are run on CircleCI on every github commit.

Tests can be run locally by running the following at the command line:

flake8 mindscope_qc
pytest

Creating & Tracking Issues

If you note a new data issue, here are steps to follow to log it:

  1. Click on the 'Issues' tab to the top/left of the page: image

  2. Try searching for related issues. If there is a currently an open issue that covers the same topic, consider adding to that issue rather than creating a new issue.

  3. If a new issue is warranted, use the button to create a new issue and select the appropriate issue type:

    • bug report: report bugs in mouse seeks or the current qc system. Examples include plots not populating, a metric no longer functioning as expected
    • QC issue: if there is a new qc issue or trend that arises that isn't covered by the current qc reporting system. Examples include consistent failures on a particular microscope, discovery of some previously unknown failure modality
    • feature request: to add new metrics or plots or update existing metrics & plots
  4. Be as descriptive as possible with your issue reporting. Use the issue template as a guide but please include:

    • A descriptive title
    • Text describing the context - how did you discover the issue, what do you think might be causing it, etc. Be as descriptive as possible!
    • Screenshots, photos, etc. Github makes it very easy to include images inline with text.
    • Relevant code blocks. If you discovered the issue during analysis, please include all code necessary to re-create the issue. Raw text is preferrable to a screenshot of code - this allows someone following up to copy/paste/run your code. Use the 'insert code' formatting button to delineate code from text image
    • Links to any other relevant issues. If you are referencing other issues in this repository, simply typing # followed by the issue number will create a hyperlink
  5. Add relevant labels. The 'Labels' dropdown is just to the right of the main comment field. Consider if your issue or feature request is related to a specific:

    • project
    • microscope or microscope type
    • data stream (e.g. eye tracking, running wheel etc.)
  6. Tag any relevant individuals in the issue text. Including their github username after the @ symbol will ensure that they are notified of the issue and any followup comments.

  7. Assign someone, including yourself. The individual(s) listed under Assignees are responsible for followup. Add people if you know they should be here, or leave it blank if you're not sure.

  8. Follow up! If you have additional information or context to provide later, return to the issue and add new comments. Try to avoid editing previous comments as this makes tracking difficult.

  9. Close the issue when it is solved.

Code Contributions

Contributing to this repo is welcome an encouraged! We hope to build a collaborative code base that is both durable in it's ability to access data and provide qc metrics and plots, and flexible in it's ability to accomodate many different projects. To keep our repo robust we require that contributions include:

  • documentation with numpy style docstrings, and use type hints
  • follow PEP 8 style guide
  • have relevant unit tests, pre-conditions and post-conditions

Documentation and Style

Documentation is required.

Please follow the PEP 8 style guide.

In addition to all inline comments, please provide numpy style docstrings for all functions and includes the following items at a minimum:

  • summary
  • parameters
  • returns
    """[summary]

    Parameters
    ----------
    input_variable : [type]
        [description]

    Returns
    -------
    [type]
        [description]
    """

pro-tip: if using Visual Studio Code the extension AutoDocstring from publisher:"Nils Werner" will automatically generate docstring template for you.

Type hints in the function definition are also highly encouraged. Example:

def cast_int_to_string(input_integer:int) -> str:
    """casts an integer into a string

    Parameters
    ----------
    input_integer : int
        any integer

    Returns
    -------
    str
        a string of the input integer
    """

Pull Requests

Pull requests are welcome!

  1. Fork the repo
  2. Create a feature branch
  3. Commit your changes
  4. Create a pull request
  5. Tag @downtoncrabby, @matchings and @seanmcculloch to review

Contributors:

Additional Links