A napari plugin for loading data from yt
Project description
yt-napari
A napari plugin for loading data from yt.
This readme provides a brief overview including:
Full documentation is available at yt-napari.readthedocs.io.
Installation
1. (optional) install yt
and napari
If you skip this step, the installation in the following section will only install the minimal package requirements for yt
or napari
, in which case you will likely need to manually install some packages. So if you are new to either package, or if you are installing in a clean environment, it may be simpler to install these packages first.
For napari
,
pip install napari[all]
will install napari
with the default Qt
backend (see here for how to choose between PyQt5
or PySide2
).
For yt
, you will need yt>=4.0.1
and any of the optional dependencies for your particular workflow. If you know that you'll need more than the base yt
install, you can install the full suite of dependent packages with
pip install yt[full]
See the yt
documentation for more information. If you're not sure which packages you'll need but don't want the full yt installation, you can proceed to the next step and then install any packages as needed (you will receive error messages when a required package is missing).
2. install yt-napari
You can install the yt-napari
plugin with:
pip install yt-napari
If you are missing either yt
or napari
(or they need to be updated), the above installation will fetch and run a minimal installation for both.
To install the latest development version of the plugin instead, use:
pip install git+https://github.com/data-exp-lab/yt-napari.git
Note that if you are working off the development version, be sure to use the latest documentation for reference: https://yt-napari.readthedocs.io/en/latest/
Quick Start
After installation, there are three modes of using yt-napari
:
- jupyter notebook interaction (jump down)
- loading a json file from the napari gui (jump down)
- napari widget plugins (jump down)
jupyter notebook interaction
yt-napari
provides a helper class, yt_napari.viewer.Scene
that assists in properly aligning new yt selections in the napari viewer when working in a Jupyter notebook.
import napari
import yt
from yt_napari.viewer import Scene
from napari.utils import nbscreenshot
viewer = napari.Viewer()
ds = yt.load("IsolatedGalaxy/galaxy0030/galaxy0030")
yt_scene = Scene()
left_edge = ds.domain_center - ds.arr([40, 40, 40], 'kpc')
right_edge = ds.domain_center + ds.arr([40, 40, 40], 'kpc')
res = (600, 600, 600)
yt_scene.add_region(viewer,
ds,
("enzo", "Temperature"),
left_edge=left_edge,
right_edge=right_edge,
resolution=res)
yt_scene.add_region(viewer,
ds,
("enzo", "Density"),
left_edge=left_edge,
right_edge=right_edge,
resolution=res)
nbscreenshot(viewer)
yt_scene.add_to_viewer
accepts any of the keyword arguments allowed by viewer.add_image
. See the full documentation (yt-napari.readthedocs.io) for more examples, including additional helper methods for linking layer appearance.
Additionally, with yt_napari
>= v0.2.0, you can use the yt_napari.timeseries
module to help sample and load in selections from across datasets.
loading a selection from a yt dataset interactively
yt-napari
provides two ways to sample a yt dataset and load in an image layer into a Napari viewer: the yt Reader plugin and json file specification.
using the yt Reader plugin
To use the yt Reader plugin, click on Plugins -> yt-napari: yt Reader
. From there, add a region or slice selector then specify a field type and field and bounds to sample between and then simply click "Load":
You can add multiple selections and load them all at once or adjust values and click "Load" again.
using the yt Time Series Reader plugin
To use the yt Time Series Reader plugin, click on Plugins -> yt-napari: yt Time Series Reader
. Specify your file matching: use file_pattern
to enter glob expressions or use file_list
to enter a list of specific files.
Then add a slice or region to sample for each matched dataset file (note: be careful of memory here!):
using a json file and schema
yt-napari
also provides the ability to load json that contain specifications for loading a file. Properly formatted files can be loaded from the napari GUI as you would load any image file (File->Open
). The json file describes the selection process for a dataset as described by a json-schema. The following json file results in similar layers as the above examples:
{"$schema": "https://raw.githubusercontent.com/data-exp-lab/yt-napari/main/src/yt_napari/schemas/yt-napari_0.0.1.json",
"datasets": [{"filename": "IsolatedGalaxy/galaxy0030/galaxy0030",
"selections": {"regions": [{
"fields": [{"field_name": "Temperature", "field_type": "enzo", "take_log": true},
{"field_name": "Density", "field_type": "enzo", "take_log": true}],
"left_edge": [460.0, 460.0, 460.0],
"right_edge": [560.0, 560.0, 560.0],
"resolution": [600, 600, 600]
}]},
"edge_units": "kpc"
}]
}
To help in filling out a json file, it is recommended that you use an editor capable of parsing a json schema and displaying hints. For example, in vscode, you will see field suggestions after specifying the yt-napari
schema:
See the full documentation at yt-napari.readthedocs.io for a complete specification.
Contributing
Contributions are very welcome! Development follows a fork and pull request workflow. To get started, you'll need a development installation and a testing environment.
development environment
To start developing, fork the repository and clone your fork to get a local copy. You can then install in development mode with
pip install -e .
tests and style checks
Both bug fixes and new features will need to pass the existing test suite and style checks. While both will be run automatically when you submit a pull request, it is helpful to run the test suites locally and run style checks throughout development. For testing, you can use tox to test different python versions on your platform.
pip install tox
And then from the top level of the yt-napari
directory, run
tox
Tox will then run a series of tests in isolated environments. In addition to checking the terminal output for test results, the tox run will generate a test coverage report: a coverage.xml
file and a htmlcov
folder -- to view the results, open htmlcov/index.html
in a browser.
If you prefer a lighter weight test, you can also use pytest
directly and rely on the Github CI to test different python versions and systems. To do so, first install pytest
and some related plugins:
pip install pytest pytest-qt pytest-cov
Now, to run the tests:
pytest -v --cov=yt_napari --cov-report=html
In addition to telling you whether or not the tests pass, the above command will write out a code coverage report to the htmlcov
directory. You can open up htmlcov/index.html
in a browser and check out the lines of code that were missed by existing tests.
For style checks, you can use pre-commit to run checks as you develop. To set up pre-commit
:
pip install pre-commit
pre-commit install
after which, every time you run git commit
, some automatic style adjustments and checks will run. The same style checks will run when you submit a pull request, but it's often easier to catch them early.
After submitting a pull request, the pre-commit.ci
bot will run the style checks. If style checks fail, you can have the bot attempt to auto-fix the failures by adding the following in a comment on it's own:
pre-commit.ci autofix
The bot will then commit changes to your pull request after which you will want to run git pull
locally to update your local version of the branch before making further changes to the branch.
building documentation locally
Documentation can be built using sphinx
in two steps. First, update the api mapping with
sphinx-apidoc -f -o docs/source src/yt_napari/
This will update the rst
files in docs/source/
with the latest docstrings in yt_napari
. Next, build the html documentation with
make html
updating the pydantic models and schema
The schema versioning follows a major.minor.micro
versioning pattern that matches the yt-napari versioning. Each yt-napari release should have an accompanying updated schema file, even if the contents of the schema file have not changed. On-disk schema are stored in src/yt_napari/schemas/
, with copies in the documentation at docs/_static
.
There are a number of utilities to help automate the management of schema in repo_utilities/
. The easiest way to use these utitities is with taskipy
from the command line. To list available scripts:
task --list
Before a release, run
task validate_release vX.X.X
where vX.X.X
is the version of the upcoming release. This script will run through some checks that ensure:
- the on-disk schema matches the schema generated by the pydantic model
- the schema files in the documentation match the schema files in the package
If any of the checks fail, you will be advised to update the schema using update_schema_docs
. If you
run without providing a version:
task update_schema_docs
It will simply copy over the existing on-disk schema files to the documentation. If you run with a version:
task update_schema_docs -v vX.X.X
It will write a schema file for the current pydantic model, overwriting any on-disk schema files for the provided version.
License
Distributed under the terms of the BSD-3 license, "yt-napari" is free and open source software
Issues
If you encounter any problems, please file an issue along with a detailed description.
Funding
The yt-napari plugin project was funded with support from the Chan Zuckerberg Initiative through the napari Plugin Accelerator Grants project, Enabling Access To Multi-resolution Data.
This napari plugin was generated with Cookiecutter using @napari's cookiecutter-napari-plugin template.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file yt_napari-0.5.0.tar.gz
.
File metadata
- Download URL: yt_napari-0.5.0.tar.gz
- Upload date:
- Size: 64.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.0 CPython/3.12.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | bd44c105cde9c7fa79ba915a273e3c4ead1ddaf1394b81d4718a6e7d4b1e8ede |
|
MD5 | 8d3bde7e7a9a65c99c0bba7afa5b4c1c |
|
BLAKE2b-256 | 397e00708833c184dbbd92f2e132aaf0957f533706aa75a1418dd3f7a61243f7 |
File details
Details for the file yt_napari-0.5.0-py3-none-any.whl
.
File metadata
- Download URL: yt_napari-0.5.0-py3-none-any.whl
- Upload date:
- Size: 63.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.0 CPython/3.12.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 77dde2ff033575cd79f0558773c749c7ec8b3ed1d2090561c638195efd91f709 |
|
MD5 | 1f7e574d8dafcb87f274de9f9dd79efb |
|
BLAKE2b-256 | 6f049b193f53d690d3053baf472650d98090214952d2ff28427927b18970851d |