xrspatial.sky_view_factor.sky_view_factor#
- xrspatial.sky_view_factor.sky_view_factor(agg: DataArray, max_radius: int = 10, n_directions: int = 16, cellsize_x: float | None = None, cellsize_y: float | None = None, name: str | None = 'sky_view_factor') DataArray[source]#
Compute the sky-view factor for each cell of a DEM.
SVF measures the fraction of the sky hemisphere visible from each cell on a scale from 0 (fully obstructed) to 1 (flat open terrain). Rays are cast at n_directions evenly spaced azimuths out to max_radius cells, and the maximum elevation angle along each ray determines the horizon obstruction.
The horizon angle along each ray uses true ground distance (
cell_step * cellsize), so cell size must be in the same unit as the elevation values (e.g. meters for both).- Parameters:
agg (xarray.DataArray or xr.Dataset) – 2D NumPy, CuPy, NumPy-backed Dask, or CuPy-backed Dask xarray DataArray of elevation values. If a Dataset is passed, the operation is applied to each data variable independently.
max_radius (int, default=10) – Maximum search distance in cells along each ray direction.
n_directions (int, default=16) – Number of azimuth directions to sample, evenly spaced around 360 degrees.
cellsize_x (float, optional) – Ground distance per cell along the x axis, in the same unit as the elevation values. If not provided, it is read from
agg.attrs['res']or computed from the x coordinate.cellsize_y (float, optional) – Ground distance per cell along the y axis, in the same unit as the elevation values. If not provided, it is read from
agg.attrs['res']or computed from the y coordinate.name (str, default='sky_view_factor') – Name of the output DataArray.
- Returns:
2D array of SVF values in [0, 1] with the same shape, coords, dims, and attrs as the input. Edge cells use truncated rays that stop at the raster boundary.
- Return type:
xarray.DataArray or xr.Dataset
References
Zakek, K., Ostir, K., Kokalj, Z. (2011). Sky-View Factor as a Relief Visualization Technique. Remote Sensing, 3(2), 398-415.
Examples
>>> from xrspatial import sky_view_factor >>> svf = sky_view_factor(dem, max_radius=100, n_directions=16)