Skip to main content

PyVista-based 3D visualization for atmospheric data

Project description

skyvista

3D gridded atmospheric data visualization in Python

skyvista provides scientifically accurate 3D visualization of gridded atmospheric science data (but likely applicable in many other disciplines). Skyvista's visualizations are primarily built on top of the pyvista library, and with the appropriate setup can be rendered directly in jupyter notebooks or IDEs, or written to disk. Pyvista is capable of creating interactive visualizations in pure HTML, making these visualizations conveniently portable. Skyvista also contains simplified functionality for creating animations of 3D data using pyvista, in addition to single visualizations.

Skyvista also contains functionality for exporting meshes and volumes created with pyvista to a variety of file formats. One intended use of this functionality is to create visualizations in Blender, using the optional [blender] addon functionality. Skyvista can handle things like setting up animations from a set of single-timestep output files, assigning shaders, as well as more complicated logic.

Further documentation is forthcoming!

Features

  • Gridded data visualization: Create sets of isosurfaces, volumes, vectors, or planes (for things like land/ocean surfaces or cross-sections) from xarray datasets
  • Trajectory visualization: Visualize Lagrangian trajectory data, with options to show trajectories as continuous arrows or as particles at their instantaneous positions (among other visualization customizations)
  • Animation support: Generate animations of time-evolving gridded atmospheric data
  • Camera control: Advanced camera positioning and following for dynamic views
  • Blender functionality: Export meshes to Blender and setup scenes and animations
  • Convenience API: Simple functions for quick visualizations

Installation

First install Skyvista, which will install pyvista as a dependency:

pip install skyvista

From here, pyvista configuration may be complicated depending on your setup. We recommend following the pyvista installation documentation and ensuring that you can successfully create an interactive bunny visualization, following the documentation's example:

from pyvista import examples
dataset = examples.download_bunny()
dataset.plot(cpos='xy')

Quick Start

Gridded model or observation data

import skyvista as sv
import xarray as xr

# Create a plot of vertical velocity and condensate loading isosurfaces

# Load gridded data
storm_ds = xr.open_dataset("model_output.nc")
quick_plot(
    simulation_ds=storm_ds,
    contours={
        # Vertical velocity
        "W": {
            "isosurfaces": [1, 3, 5, 10],
            "cmap": "Greens",
            "opacity": 0.8,
        },
        # Condensate loading
        "RC": {
            # Isosurfaces will be calculated automatically if not specified
            "cmap": "Blues",
            "opacity": 0.4,
        }
    },

Data Format

Gridded data

Gridded data should be xarray Datasets with dimensions x, y, z, and optionally time if creating an animation:

import xarray as xr

# Example DataArray; this should be a data variable in an xr.Dataset,
# not passed directly into skyvista
cloud_field = xr.DataArray(
    data=3d_array,
    dims=['x', 'y', 'z'],
    coords={
        'x': x_coordinates,
        'y': y_coordinates,
        'z': z_coordinates,
    }
)

License

MIT License

Citation

If you use skyvista in your research, please cite:

@software{skyvista,
  author = {Davis, Charles},
  title = {skyvista: 3D gridded atmospheric data visualization in Python},
  year = {2026},
  url = {https://github.com/cmdavis4/skyvista}
}

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

skyvista-0.1.1.tar.gz (58.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

skyvista-0.1.1-py3-none-any.whl (62.3 kB view details)

Uploaded Python 3

File details

Details for the file skyvista-0.1.1.tar.gz.

File metadata

  • Download URL: skyvista-0.1.1.tar.gz
  • Upload date:
  • Size: 58.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.3

File hashes

Hashes for skyvista-0.1.1.tar.gz
Algorithm Hash digest
SHA256 5997e1f7ac870b3fa00581053eed03e5e8d9beed376a375de9be332ec708c91b
MD5 a84bf54ae072230d9f2d0897dee006d5
BLAKE2b-256 c784d2c42a4e69850efd7b7b24f2b2270f5a55284f498614218e4ee109e2a9cc

See more details on using hashes here.

File details

Details for the file skyvista-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: skyvista-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 62.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.3

File hashes

Hashes for skyvista-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 a3b1682111544824c01d12dd55e875db38668ddd3611dbff2e31041b7127aa4e
MD5 b421fd231a979e1f646684899dd861bd
BLAKE2b-256 9a76ebaeed87a51f3be8497f5f1a89824fd7b66e66ae72d10df7e523a360389b

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page