Raster-based Spatial Analysis for Python

Overview

🌍 xarray-spatial: Raster-Based Spatial Analysis in Python

Build Status Build status PyPI version Downloads License


History of OS GIS Timeline


title

📍 Fast, Accurate Python library for Raster Operations

⚡ Extensible with Numba

⏊ Scalable with Dask

🎊 Free of GDAL / GEOS Dependencies

🌍 General-Purpose Spatial Processing, Geared Towards GIS Professionals


Xarray-Spatial implements common raster analysis functions using Numba and provides an easy-to-install, easy-to-extend codebase for raster analysis.

Installation

# via pip
pip install xarray-spatial

# via conda
conda install -c conda-forge xarray-spatial

Dowloading our starter examples and data

Once you have xarray-spatial installed in your environment, you can use one of the following in your terminal (with the environment active) to download our examples and/or sample data into your local directory.

xrspatial examples : Download the examples notebooks and the data used.

xrspatial copy-examples : Download the examples notebooks but not the data. Note: you won't be able to run many of the examples.

xrspatial fetch-data : Download just the data and not the notebooks.

In all the above, the command will download and store the files into your current directory inside a folder named 'xrspatial-examples'.

xarray-spatial grew out of the Datashader project, which provides fast rasterization of vector data (points, lines, polygons, meshes, and rasters) for use with xarray-spatial.

xarray-spatial does not depend on GDAL / GEOS, which makes it fully extensible in Python but does limit the breadth of operations that can be covered. xarray-spatial is meant to include the core raster-analysis functions needed for GIS developers / analysts, implemented independently of the non-Python geo stack.

Our documentation is still under constructions, but docs can be found here.

Raster-huh?

Rasters are regularly gridded datasets like GeoTIFFs, JPGs, and PNGs.

In the GIS world, rasters are used for representing continuous phenomena (e.g. elevation, rainfall, distance), either directly as numerical values, or as RGB images created for humans to view. Rasters typically have two spatial dimensions, but may have any number of other dimensions (time, type of measurement, etc.)

Supported Spatial Functions with Supported Inputs


Classification

Name NumPy xr.DataArray Dask xr.DataArray CuPy GPU xr.DataArray Dask GPU xr.DataArray
Equal Interval ✅ī¸ ✅ ✅ ✅ī¸
Natural Breaks ✅ī¸ ✅ ✅ ✅ī¸
Reclassify ✅ī¸ ✅ ✅ ✅
Quantile ✅ī¸ ✅ ✅ ✅ī¸

Focal

Name NumPy xr.DataArray Dask xr.DataArray CuPy GPU xr.DataArray Dask GPU xr.DataArray
Apply ✅ī¸
Hotspots ✅ī¸
Mean ✅ī¸
Focal Statistics ✅ī¸ ✅ī¸

Multispectral

Name NumPy xr.DataArray Dask xr.DataArray CuPy GPU xr.DataArray Dask GPU xr.DataArray
Atmospherically Resistant Vegetation Index (ARVI) ✅ī¸ ✅ī¸ ✅ī¸ ✅ī¸
Enhanced Built-Up and Bareness Index (EBBI) ✅ī¸ ✅ī¸ ✅ī¸ ✅ī¸
Enhanced Vegetation Index (EVI) ✅ī¸ ✅ī¸ ✅ī¸ ✅ī¸
Green Chlorophyll Index (GCI) ✅ī¸ ✅ī¸ ✅ī¸ ✅ī¸
Normalized Burn Ratio (NBR) ✅ī¸ ✅ī¸ ✅ī¸ ✅ī¸
Normalized Burn Ratio 2 (NBR2) ✅ī¸ ✅ī¸ ✅ī¸ ✅ī¸
Normalized Difference Moisture Index (NDMI) ✅ī¸ ✅ī¸ ✅ī¸ ✅ī¸
Normalized Difference Vegetation Index (NDVI) ✅ī¸ ✅ī¸ ✅ī¸ ✅ī¸
Soil Adjusted Vegetation Index (SAVI) ✅ī¸ ✅ī¸ ✅ī¸ ✅ī¸
Structure Insensitive Pigment Index (SIPI) ✅ī¸ ✅ī¸ ✅ī¸ ✅ī¸

Pathfinding

Name NumPy xr.DataArray Dask xr.DataArray CuPy GPU xr.DataArray Dask GPU xr.DataArray
A* Pathfinding ✅ī¸

Proximity

Name NumPy xr.DataArray Dask xr.DataArray CuPy GPU xr.DataArray Dask GPU xr.DataArray
Allocation ✅ī¸
Direction ✅ī¸
Proximity ✅ī¸

Surface

Name NumPy xr.DataArray Dask xr.DataArray CuPy GPU xr.DataArray Dask GPU xr.DataArray
Aspect ✅ī¸ ✅ī¸ ✅ī¸ ⚠ī¸
Curvature ✅ī¸ ⚠ī¸
Hillshade ✅ī¸ ✅ī¸
Slope ✅ī¸ ✅ī¸ ✅ī¸ ⚠ī¸
Terrain Generation ✅ī¸
Viewshed ✅ī¸
Perlin Noise ✅ī¸
Bump Mapping ✅ī¸

Zonal

Name NumPy xr.DataArray Dask xr.DataArray CuPy GPU xr.DataArray Dask GPU xr.DataArray
Apply ✅ī¸
Crop ✅ī¸
Regions ✅ī¸
Trim ✅ī¸
Zonal Statistics ✅ī¸
Zonal Cross Tabulate ✅ī¸

Usage

Basic Pattern
import xarray as xr
from xrspatial import hillshade

my_dataarray = xr.DataArray(...)
hillshaded_dataarray = hillshade(my_dataarray)

Check out the user guide here.


title title

Dependencies

xarray-spatial currently depends on Datashader, but will soon be updated to depend only on xarray and numba, while still being able to make use of Datashader output when available.

title

Notes on GDAL

Within the Python ecosystem, many geospatial libraries interface with the GDAL C++ library for raster and vector input, output, and analysis (e.g. rasterio, rasterstats, geopandas). GDAL is robust, performant, and has decades of great work behind it. For years, off-loading expensive computations to the C/C++ level in this way has been a key performance strategy for Python libraries (obviously...Python itself is implemented in C!).

However, wrapping GDAL has a few drawbacks for Python developers and data scientists:

  • GDAL can be a pain to build / install.
  • GDAL is hard for Python developers/analysts to extend, because it requires understanding multiple languages.
  • GDAL's data structures are defined at the C/C++ level, which constrains how they can be accessed from Python.

With the introduction of projects like Numba, Python gained new ways to provide high-performance code directly in Python, without depending on or being constrained by separate C/C++ extensions. xarray-spatial implements algorithms using Numba and Dask, making all of its source code available as pure Python without any "black box" barriers that obscure what is going on and prevent full optimization. Projects can make use of the functionality provided by xarray-spatial where available, while still using GDAL where required for other tasks.

Contributors

  • @brendancol
  • @thuydotm
  • @jbednar
  • @pablomakepath
  • @kristinepetrosyan
  • @sjsrey
  • @giancastro
  • @ocefpaf
  • @rsignell-usgs
  • @marcozimmermannpm
  • @jthetzel
  • @chase-dwelle
  • @SAN154
  • @SapirLastimoza-Dooley
  • @lex-c
Comments
  • Add annulus focal kernel

    Add annulus focal kernel

    Addresses #125, #124

    Using the circle kernel to extend to an annulus kernel. Implementation excludes the cells on the bound of the inner radius of the annulus.

    Also implements the ability to return the raw z-scores from hotspots.

    opened by chase-dwelle 7
  • fix tarball and drop versioneer

    fix tarball and drop versioneer

    versioneer is deprecated, does not work properly with pep517/518, and the source distribution tarball on PyPI is broken without the versioneer.py file in it. See https://github.com/conda-forge/staged-recipes/pull/12177

    This PR implements setuptools_scm instead of versioneer, modernize the Travis-CI a little bit and implement a tarball check to avoid regressions, and fix the tarball.

    Ping @rsignell-usgs who requested the conda-forge package.

    Needed in https://github.com/conda-forge/staged-recipes/pull/12177

    opened by ocefpaf 7
  • Added a pure numba hillshade that is 10x faster compared to numpy

    Added a pure numba hillshade that is 10x faster compared to numpy

    The new code uses less context switching and data transfers, minimizes communication overhead and removes the cupy dependency. I've made it run by default, if cuda is available. Otherwise if falls back to numpy

    This change addresses issue #541

    opened by a7az0th 6
  • Add distributed proximity distance grids using Dask

    Add distributed proximity distance grids using Dask

    Given a 2D raster image, a set of target pixels in the input raster, the proximity function computes a raster of proximity to indicate the distance from each pixel to the nearest target pixel. The distance metric to be used can be one of the following: Euclidean, Great-Circle, or Manhattan. In the most naive way, we can calculate distances from each pixel to all target pixels and find the closest target. This would take m*n*t calculations, where m*n is the size of the raster, and t is the number of targets.

    The current implementation of xrspatial.proximity function is ported from GDAL with some modifications to make it work with xarray.DataArray. This notebook shows how to use the function. To keep it simple, let's consider the problem at a 2D array level instead of a 2D xarray DataArray. The algorithm can be described as follows:

    Inputs:

    • Raster image I, a height x width 2D array
    • Set of target pixels T. All target pixels are in I
    • Distance metric d()

    Output: Proximity raster P where P[i, j] is the distance from cell (i, j) to its nearest target pixel

    Idea: Use dynamic programming to identify the nearest target pixel of a pixel based on the nearest target pixels of its 3x3 neighborhood window.

    Detail implementation:

    • Let Nx be a 1d array of width elements: Nx[j] is the x-position in pixel space of nearest target pixel of pixel (i, j). Nx[j] can have a value in [0, width-1]
    • Let Ny be a 1d array of width elements: Ny[j] is the y-position in pixel space of nearest target pixel of pixel (i, j). Ny[j] can have a value in [0, height-1]. Values of Nx and Ny will be updated row by row.
    1. Initially,
    • set Nx[j] = -1 for all j.
    • set Ny[j] = -1 for all j.
    • for all (i, j), set P[i, j] = 0 if cell (i, j) is a target pixel, P[i, j] = infinity otherwise.
    • note that distance d( (i1, j1), (i2, j2) ) = infinity if any of the inputs i1, j1, i2, j2 equals to -1 (i.e, invalid pixel)
    1. Traverse the image row by row from top to bottom:
    • traverse each row from left to right
    • traverse each row from right to left
    1. Reset Nx[j] = -1 and Ny[j] = -1 for all j.
    2. Traverse the image in reverse order from bottom to top:
    • traverse each row from right to left
    • traverse each row from left to right

    The formula to update P[i, j] and Ny[j] and Nx[j] at each cell (i, j)

    P[i, j] = min(
        P[i, j],                   
        d( (Ny[j], Nx[j]), (i, j) ),     # Are we nearer to the closest target to the above (below) pixel?
        d( (Ny[j-1], Nx[j-1]), (i, j) ), # Are we nearer to the closest target to the left (right) pixel?
        d( (Ny[j+1], Nx[j+1]), (i, j) ), # Are we nearer to the closest target to the top right (bottom left) pixel?
    )
    

    Update Ny[j] and Nx[j] accordingly:

    • Ny[j], Nx[j] = i, j if P[i, j] = 0
    • Ny[j], Nx[j] = Ny[j-1], Nx[j-1] if P[i, j] is updated as d( (Ny[j-1], Nx[j-1]), (i, j) )
    • Ny[j], Nx[j] = Ny[j+1], Nx[j+1] if P[i, j] is updated as d( (Ny[j+1], Nx[j+1]), (i, j) )

    We're looking for an implementation for the distributed version of the Proximity function that works with Dask. Explicit questions are listed as:

    1. Currently, the calculations are performed sequentially, how to parallelize them?
    2. Dividing our 2D input data into a set of smaller chunks, how to compute proximity distance grid chunk by chunk? The primary question is, how to determine the nearest target pixel of all pixels in a chunk when the target pixels can be outside the chunk?
    technical-assistance-needed 
    opened by marcozimmermannpm 6
  • nodata_value for zonal_stats doesn't appear to work

    nodata_value for zonal_stats doesn't appear to work

    Describe the bug Running zonal_stats and passing in the argument nodata_values = -99999 results in a ValueError: All arrays must be of the same length stack trace with method and line number zonal.py line 519 zonal.py 335 python3.7/site-packages/pandas/core/frame.py 614 python3.7/site-packages/pandas/core/internals/construction.py 465

    When i run zonal_stats without the nodata_values argument it runs fine and computes

    nodata_values = -99999 or nodata_values = -99999.0

    Expected behavior Would expect the method zonal_stats to return statistics computed ignoring pixels with nodata_values

    Screenshots Unable to provide screenshots, running this in a classified environment

    Desktop (please complete the following information): Running this in Databricks 7.3LTS with Python 3.7.5, xarray-spatial 0.3.0

    bug 
    opened by petersedivec 5
  • Compat error with `numpy>1.20`

    Compat error with `numpy>1.20`

    Describe the bug Cannot install the latest version of xarray-spatial with an up-to-date stack (numpy>1.20).

    Expected behavior Install the latest version of xarray-spatial through conda

    Screenshots I'm trying to update the gds_env and trying an install that pins xarray-spatial to its latest release returns the following error:

    package xarray-spatial-0.2.9-pyhd8ed1ab_0 requires numpy >=1.7,<=1.20, but none of the providers can be installed
    

    The numpy version it is installing (for compatibility with other libraries) is 1.21.2. Is there any reason why it pins to 1.20 as the most recent version?

    bug 
    opened by darribas 5
  • Optl reproj

    Optl reproj

    Added reprojection with one blank function to test optional modules install. Can be extended to other modules as well. Install with pip install -e . --install-option='--reprojection' to get reprojection module.

    ready to merge 
    opened by calexat-123 5
  • Ready: Fix examples download cli cmd

    Ready: Fix examples download cli cmd

    Changed versioning scheme. The scm versioning in setup py was not working correctly. I substituted from param (as in datashader) to generate versions. Conda versions are fixed at 0.1.6 right now.

    ready to merge 
    opened by calexat-123 5
  • Remove numpy version pin

    Remove numpy version pin

    Now that numba 0.55 has been released with support for numpy 1.21 and python 3.10, we no longer need to pin to a max numpy version ourselves.

    Fixes issue #565.

    opened by ianthomas23 4
  • Fast terrain

    Fast terrain

    This PR brings all the terrain generation related development and optimization. In brief:

    • adds a fast_perlin.py module that contains a fast_perlin() method that can be used to generate perlin noise. It offers higher performance compared to the previous implementation of perlin noise and has a Numpy, CuPy and Dask implementation. Note that the interface is now slightly different. The user needs to pass an xr.DataArray (can be based on numpy, cupy or dask array) instead of width, height.
    • adds a fast_terrain.py module that contains a generate_fast_terrain() method that can be used to generate a randomized terrain. It is faster compare to the existing implementation of terrain generation. Uses the fast_perlin() method and has a Numpy, CuPy and Dask implementation. Note that the interface is now slightly different. The user needs to pass an xr.DataArray (can be based on numpy, cupy or dask array) instead of a Canvas.
    • Adds two jupyter notebooks in the examples directory, one for each of the two newly added methods.
    opened by kiliakis 4
  • Update Release note versions

    Update Release note versions

    Hey the last few releases need the CHANGELOG.md information copied over. to the github Release for each version (e.g. 0.1.4, 0.1.5, 0.1.6). Check those out, the content should be fine the way it is.

    opened by brendancol 4
  • Discrepancy between xarray-spatial hillshade and GDAL hillshade

    Discrepancy between xarray-spatial hillshade and GDAL hillshade

    I'm testing xarray-spatial against QGIS and seeing that when running hillshade on the same input data, the results by xarray-spatial and GDAL/QGIS are very different. Source code for QGIS hillshade can be found at: https://github.com/qgis/QGIS/blob/master/python/plugins/processing/algs/gdal/hillshade.py. This needs more research to see how the algorithm was implemented in QGIS to clearly understand the difference between the 2 libraries.

    Input data:

    array([[      nan,       nan,       nan,       nan,       nan,       nan],
           [704.237  , 242.24084, 429.3324 , 779.8816 , 193.29506, 984.6926 ],
           [226.56795, 815.7483 , 290.6041 ,  76.49687, 820.89716,  32.27882],
           [344.8238 , 256.34998, 806.8326 , 602.0442 , 721.1633 , 496.95636],
           [185.43515, 834.10425, 387.0871 , 716.0262 ,  49.61273, 752.95483],
           [302.4271 , 151.49211, 442.32797, 358.4702 , 659.8187 , 447.1241 ],
           [148.04834, 819.2133 , 468.97913, 977.11694, 597.69666, 999.14185],
           [268.1575 , 625.96466, 840.26483, 448.28333, 859.2699 , 528.04095]],
          dtype=float32)
    

    xarray-spatial hillshade:

    array([[       nan,        nan,        nan,        nan,        nan,            nan],
           [       nan,        nan,        nan,        nan,        nan,            nan],
           [       nan, 0.75030494, 0.06941041, 0.90643436, 0.15474272,            nan],
           [       nan, 0.80836594, 0.72366774, 0.14052185, 0.774778  ,            nan],
           [       nan, 0.93396175, 0.7071851 , 0.42872226, 0.9455124 ,            nan],
           [       nan, 0.85551083, 0.6819584 , 0.46013114, 0.23561102,            nan],
           [       nan, 0.41484872, 0.3213355 , 0.5821109 , 0.21879822,            nan],
           [       nan,        nan,        nan,        nan,        nan,            nan]],
     dtype=float32)
    

    QGIS/GDAL hillshade

    array([[  0.      ,   0.      ,   0.      ,   0.      ,   0.      ,          0.      ],
           [  0.      ,   0.      ,   0.      ,   0.      ,   0.      ,          0.      ],
           [107.84468 ,  70.09885 ,   0.      ,  17.661407,   0.      ,          0.      ],
           [ 80.06987 ,  71.644684,   0.      ,   0.      ,   0.      ,          0.      ],
           [ 85.574615, 106.36669 ,  96.23605 ,  28.27108 ,  90.29079 ,         85.07072 ],
           [ 81.44522 ,  77.092354,   8.479876,   0.      ,   0.      ,          0.      ],
           [ 62.541145,   2.647696,   0.      ,   0.      ,   0.      ,          6.515689],
           [ 74.07955 ,  78.71434 ,   0.      ,  84.590744,  34.814816,         44.81609 ]],
     dtype=float32)
    
    opened by thuydotm 0
  • Hotspots time series analysis

    Hotspots time series analysis

    Many GIS data is collected frequently. For example, Sentinel-2 is captured every 5 days. Having tools that support studying data over time can help in detecting the changes, as well as identifying the trends to predict future. Time series analysis will be our next step. Let's do some research about how to do time series hotspots analysis.

    https://pro.arcgis.com/en/pro-app/latest/tool-reference/space-time-pattern-mining/emerginghotspots.htm

    https://pro.arcgis.com/en/pro-app/latest/tool-reference/spatial-statistics/space-time-analysis.htm

    opened by thuydotm 0
  • Review GPU supports for all tools

    Review GPU supports for all tools

    One of the 2023 focus is to strengthen our GPU support to xarray-spatial tools. Let's review again and address which needs improvement and what we can do.

    opened by thuydotm 0
  • Test against QGIS, GDAL

    Test against QGIS, GDAL

    To evaluate the reliability of xarray-spatial, let's test the package and compare the results against QGIS/GDAL.

    • [x] aspect
    • [x] slope
    • [x] multispectral tools
    • [x] proximity
    • [x] zonal stats

    Fixes #22, #104, #182

    ready to merge 
    opened by thuydotm 1
Releases(v0.3.5)
  • v0.3.5(Jun 5, 2022)

    The 0.3.5 release mainly addresses the scaling issue in GPU viewshed to gain better accurate triangulation. The GPU raytraced viewshed should now give comparable results to the CPU version. However, the 2 versions use 2 different approaches, there can be slightly differences at some points where a version returns visible while the other considers them as invisible. Many thanks to @nodell111, @a7az0th, and the maintainers @thuydotm for contributing to this release.

    Enhancements

    • command to get change log (#716)
    • Added Feature Proposal Template (#714)

    Bug Fixes

    • Improved viewshed rtx. Now result should match the CPU version (#715)
    Source code(tar.gz)
    Source code(zip)
  • v0.3.4(Jun 1, 2022)

    Version 0.3.4 - 2022-06-01

    The 0.3.4 release primarily a bug fix release but also includes a number of enhancements with a focus on GPU supports. Many thanks to @mkeenan195, @a7az0th, and the maintainers @ianthomas23 and @thuydotm for contributing to this release.

    Enhancements

    • NumPy zonal stats: return a data array of calculated stats (#685)
    • set unit for hotspots output (#686)
    • More robust cuda and cupy identification (#657)
    • Remove deprecated tiles module (#698)
    • Test on python 3.10, remove 3.6 (#694)
    • moved all tests to github actions (#689)
    • Add isort to pytest (#700)
    • Add flake8 to pytest (#697)
    • Remove unnecessary executable flags (#696)
    • updated test hotspots gpu (#692)
    • 3D numpy zonal_crosstab to support more agg methods (#687)

    Bug Fixes

    • Fix rtx viewshed rendering blank image (#711)
    • Convolve_2d gpu fixes (#702)
    • focal.mean(): only do data type conversion once (#699)
    • Update to remote sensing notebook (#688)
    • focal_stats(): gpu case (#709)
    • focal apply: drop gpu support (#706)
    • drop gpu support (#705)
    • enabled numba.cuda.jit in hotspots cupy (#691)

    Documentation

    • Correct examples in docstrings (#703)
    • Fix doc build dependencies in CI (#683)
    • Fix link to Austin road network notebook (#695)
    Source code(tar.gz)
    Source code(zip)
  • v0.3.3(Mar 21, 2022)

    • fixed ubuntu version (#681)
    • Don't calculate angle when not needed (#677)
    • codecov: ignore all tests at once (#674)
    • add more tests to focal module (#676)
    • classify: more tests (#675)
    • Codecov: disable Numba; ignore tests, experimental, and gpu_rtx (#673)
    • Improve linter: add isort (#672)
    • removed stale test files from project root (#670)
    • User guide fixes (#665)
    • license year in README to include 2022 (#668)
    • install dependencies specified in test config (#666)
    • Pytests for CuPy zonal stats (#658)
    • add Codecov badge to README
    • codecov with github action (#663)
    • Modernise build system (#654)
    • classify tools: classify infinite values as nans, natural_breaks: classify all data points when using sub sample (#653)
    • Add more benchmarks (#648)
    • Stubbed out function for Analytics module (#621)
    • Fix doc build failure due to Jinja2 version (#651)
    Source code(tar.gz)
    Source code(zip)
  • v0.3.2(Feb 4, 2022)

    • Remove numpy version pin (#637)
    • aspect: added benchmarks (#640)
    • Clean gitignore and manifest files (#642)
    • Benchmark results (#643)
    • handle CLI errors #442 (#644)
    • Cupy zonal (#639)
    • Tests improvements (#636)
    Source code(tar.gz)
    Source code(zip)
  • v0.3.1(Jan 10, 2022)

    • Add benchmarking framework using asv (#595)
    • Fix classify bug with dask array (#599)
    • polygonize function on cpu for numpy-backed xarray DataArrays (#585)
    • Test python 3.9 on CI (#602)
    • crosstab: speedup dask case (#596)
    • Add benchmark for CPU polygonize (#605)
    • Change copyright year to include 2021 (#610)
    • Docs enhancement (#604, #628)
    • code refactor: use array function mapper, add messages param to not_implemented_func() (#612)
    • condense tests (#613)
    • Multispectral fixes (#617)
    • Change copyright year to 2022 (#622)
    • Aspect: convert to float if int dtype input raster (#619)
    • direction(), allocation(): set all NaNs at initalization (#618)
    • Add rtx gpu hillshade with shadows (#608)
    • Add hillshade benchmarking, for numpy, cupy and rtxpy (#625)
    • Focal mean: handle nans inside kernel (#623)
    • Convert to float32 if input raster is in int dtype (#629)
    Source code(tar.gz)
    Source code(zip)
  • v0.3.0(Dec 1, 2021)

    • Added a pure numba hillshade that is 10x faster compared to numpy (#542)
    • dask case proximity: process whole raster at once if max_distance exceed max possible distance (#558)
    • pathfinding: start and goal in (y, x) format (#550)
    • generate_terrain: cupy case, dask numpy case (#555)
    • Optimize natural_break on large inputs (#562)
    • Fixes in CPU version of natural_breaks. (#562) (#563)
    • zonal stats, speed up numpy case (#568)
    • Ensure that cupy is not None (#570)
    • Use explicit cupy to numpy conversion in tests (#573)
    • zonal stats: speed up dask case (#572)
    • zonal_stats: ensure chunksizes of zones and values are matching (#574)
    • validate_arrays: ensure chunksizes of arrays are matching (#577)
    • set default value for num_sample (#580)
    • Add rtx gpu viewshed and improve cpu viewshed (#588)
    Source code(tar.gz)
    Source code(zip)
  • v0.2.9(Sep 1, 2021)

  • v0.2.8(Aug 27, 2021)

    • Added dask support to proximity tools (#540)
    • Refactored the resample utils function and changed their name to canvas_like (#539)
    • Added zone_ids and cat_ids param to stats zonal function (#538)
    Source code(tar.gz)
    Source code(zip)
  • v0.2.7(Jul 30, 2021)

    • Added Dask support for stats and crosstab zonal functions (#502)
    • Ignored NaN values on classify functions (#534)
    • Added agg param to crosstab zonal function (#536)
    Source code(tar.gz)
    Source code(zip)
  • v0.2.6(Jun 28, 2021)

    • Updated the classification notebook (#489)
    • Added xrspatial logo to readme (#492)
    • Removed reprojection notebook old version (#494)
    • Added true_color function to documentation (#494)
    • Added th params to true_color function (#494)
    • Added pathfinding nb data load guidance (#491)
    Source code(tar.gz)
    Source code(zip)
  • v0.2.5(Jun 24, 2021)

    • Added reprojection notebook (#474)
    • Reviewed local tools notebook (#466)
    • Removed save_cogs_azure notebook (#478)
    • Removed xrspatial install guidance from makepath channel (#483)
    • Moved local notebook to user guide folder (#486)
    • Fixed pharmacy notebook (#479)
    • Fixed path-finding notebook data load guidance (#480)
    • Fixed focal notebook imports (#481)
    • Fixed remote-sensing notebook data load guidance (#482)
    • Added output name and attrs on true_color function (#484)
    • Added classify notebook (#477)
    Source code(tar.gz)
    Source code(zip)
  • v0.2.4(Jun 10, 2021)

  • v0.2.3(Jun 2, 2021)

  • v0.2.2(May 7, 2021)

  • v0.2.1(May 7, 2021)

    • Added GPU and Dask support for Focal tools: mean, apply, hotspots (#238)
    • Moved kernel creation functions to convolution module (#238)
    • Update Code of Conduct (#391)
    • Fixed manhattan distance to sum of abs (#309)
    • Example notebooks running on PC Jupyter Hub (#370)
    • Fixed examples download cli cmd (#349)
    • Removed conda recipe (#397)
    • Updated functions and classes docstrings (#302)
    Source code(tar.gz)
    Source code(zip)
  • v0.2.0(Apr 29, 2021)

  • v0.1.9(Apr 27, 2021)

    • Deprecated tiles module (#381)
    • Added user guide on the documentation website (#376)
    • Updated docs design version mapping (#378)
    • Added Github Action to publish package to PyPI (#371)
    • Moved Spatialpandas to core install requirements for it to work on JLabs (#372)
    • Added CONTRIBUTING.md (#374)
    • Updated true_color to return a xr.DataArray (#364)
    • Added get_data module and example sentinel-2 data (#358)
    • Added citations guidelines and reformat (#382)
    Source code(tar.gz)
    Source code(zip)
  • v0.1.8(Apr 15, 2021)

  • v0.1.7(Apr 15, 2021)

    • Updated multispectral.true_color: sigmoid contrast enhancement (#339)
    • Added notebook save cogs in examples directory (#307)
    • Updated Focal user guide (#336)
    • Added documentation step on release steps (#346)
    • Updated cloudless mosaic notebook: use Dask-Gateway (#351)
    • Fixed user guide notebook numbering (#333)
    • Correct warnings (#350)
    • Add flake8 Github Action (#331)
    Source code(tar.gz)
    Source code(zip)
  • v0.1.6(Apr 13, 2021)

    • Cleared metadata in all examples ipynb (#327)
    • Moved docs requirements to source folder (#326)
    • Fixed manifest file
    • Fixed travis ci (#323)
    • Included yml files
    • Fixed examples path in Pharmacy Deserts Noteboo
    • Integrate xarray-spatial website with the documentation (#291)
    Source code(tar.gz)
    Source code(zip)
  • v0.1.5(Apr 13, 2021)

  • v0.1.4(Apr 13, 2021)

  • v0.1.3(Apr 6, 2021)

    • Added band_to_img utils func
    • Added download-examples CLI command for all notebooks (#241)
    • Added band_to_img utils func
    • docs enhancements
    • GPU and dask support for multispectral tools
    • GPU and Dask support for classify module (#168)
    • Fixed savi dask cupy test skip
    • Moved validate_arrays to utils
    • Added GPU support for hillshade (#151)
    • Added CLI for examples data
    • Improved Sphinx docs / theme
    Source code(tar.gz)
    Source code(zip)
  • v0.1.2(Dec 1, 2020)

    • Added GPU support for curvature (#150)
    • Added dask.Array support for curvature (#150)
    • Added GPU support for aspect (#156)
    • Added dask.Array support for aspect (#156)
    • Added GPU support for slope (#152)
    • Added dask.Array support for slope (#152)
    • Fixed slope cupy: nan edge effect, remove numpy padding that cause TypeError (#160)
    • Fixed aspect cupy: nan edge effect, remove numpy padding that cause TypeError(#160)
    • Updated README with Supported Spatial Features Table
    • Added badge for open source gis timeline
    • Added GPU Support for Multispectral tools (#148)
    • Added Python 3.9 to Test Suite
    Source code(tar.gz)
    Source code(zip)
  • v0.1.1(Oct 21, 2020)

  • v0.1.0(Sep 11, 2020)

    • Moved kernel creation to name-specific functions. (#127)
    • Separated the validate and custom kernel functions. (focal)
    • Added annulus focal kernel (#126) (focal)
    • Added outputting of z-scores from hotspots tool (focal)
    • Changed type checking to use np.floating (focal)
    • Added tests for refactored focal statistics (focal)
    Source code(tar.gz)
    Source code(zip)
  • v0.0.9(Aug 28, 2020)

    • Added A* pathfinding
    • Allow all numpy float data types, not just numpy.float64 (#122)
    • Broke out user-guide into individual notebooks
    • Added num_sample param option to natural_breaks (#123)
    • Removed sklearn dependency
    Source code(tar.gz)
    Source code(zip)
  • v0.0.8(Jul 22, 2020)

  • 0.0.7(Jul 22, 2020)

  • v0.0.6(Jul 15, 2020)

    Version 0.0.6 - 7/14/2020

    • Added Proximity Direction (proximity)
    • Added Proximity Allocation (proximity)
    • Added Zonal Crop (zonal)
    • Added Trim (zonal)
    • Added ebbi (multispectral)
    • Added more tests for slope (slope)
    • Added image grid (readme)
    Source code(tar.gz)
    Source code(zip)
Owner
makepath
makepath
A ninja python package that unifies the Google Earth Engine ecosystem.

A Python package that unifies the Google Earth Engine ecosystem. EarthEngine.jl | rgee | rgee+ | eemont GitHub: https://github.com/r-earthengine/ee_ex

47 Dec 27, 2022
A package to fetch sentinel 2 Satellite data from Google.

Sentinel 2 Data Fetcher Installation Create a Virtual Environment and activate it. python3 -m venv venv . venv/bin/activate Install the Package via pi

1 Nov 18, 2021
Python script to locate mobile number

Python script to locate mobile number How to use this script run the command to install the required libraries pip install -r requirements.txt run the

Shekhar Gupta 8 Oct 10, 2022
Open GeoJSON data on geojson.io

geojsonio.py Open GeoJSON data on geojson.io from Python. geojsonio.py also contains a command line utility that is a Python port of geojsonio-cli. Us

Jacob Wasserman 114 Dec 21, 2022
ColoringMapAlgorithm-CSP- - Graphical Coloring of Countries with Condition Satisfaction Algorithm

ColoringMapAlgorithm-CSP- Condition Satisfaction Algorithm Output Condition

Kerem TAN 2 Jan 10, 2022
WebGL2 powered geospatial visualization layers

deck.gl | Website WebGL2-powered, highly performant large-scale data visualization deck.gl is designed to simplify high-performance, WebGL-based visua

Vis.gl 10.5k Jan 08, 2023
Automated download of LANDSAT data from USGS website

LANDSAT-Download It seems USGS has changed the structure of its data, and so far, I have not been able to find the direct links to the products? Help

Olivier Hagolle 197 Dec 30, 2022
A light-weight, versatile XYZ tile server, built with Flask and Rasterio :earth_africa:

Terracotta is a pure Python tile server that runs as a WSGI app on a dedicated webserver or as a serverless app on AWS Lambda. It is built on a modern

DHI GRAS 531 Dec 28, 2022
Minimum Bounding Box of Geospatial data

BBOX Problem definition: The spatial data users often are required to obtain the coordinates of the minimum bounding box of vector and raster data in

Ali Khosravi Kazazi 1 Sep 08, 2022
Xarray backend to Copernicus Sentinel-1 satellite data products

xarray-sentinel WARNING: this product is a "technology preview" / pre-Alpha Xarray backend to explore and load Copernicus Sentinel-1 satellite data pr

B-Open 191 Dec 15, 2022
Helping data scientists better understand their datasets and models in text classification. With love from ServiceNow.

Azimuth, an open-source dataset and error analysis tool for text classification, with love from ServiceNow. Overview Azimuth is an open source applica

ServiceNow 145 Dec 23, 2022
Summary statistics of geospatial raster datasets based on vector geometries.

rasterstats rasterstats is a Python module for summarizing geospatial raster datasets based on vector geometries. It includes functions for zonal stat

Matthew Perry 437 Dec 23, 2022
Python 台įŖ行æ”ŋ區地圖 (2021)

Python 台įŖ行æ”ŋ區地圖 (2021) äģĨ python čŽ€å–æ”ŋåēœé–‹æ”žåšŗ台įš„ ShapeFile 地圖čŗ‡č¨Šã€‚æ­ĄčŋŽåŧ•į”¨æˆ–是協äŊœ åĻ有į¸Ŗ市čŗ‡č¨Šã€æ‘里čŗ‡č¨Ščˆ‡å„į¨ŽčĄŒæ”ŋ地圖čŗ‡č¨Š 例åĻ‚īŧš į›´čŊ„市、į¸Ŗ市į•Œįˇš(TWD97įļ“įˇ¯åēĻ) 鄉鎎市區į•Œįˇš(TWD97įļ“įˇ¯åēĻ) | æ”ŋåēœčŗ‡æ–™é–‹æ”žåšŗč‡ē: https://data

WeselyOng 12 Sep 27, 2022
Python library to visualize circular plasmid maps

Plasmidviewer Plasmidviewer is a Python library to visualize plasmid maps from GenBank. This library provides only the function to visualize circular

Mori Hideto 9 Dec 04, 2022
PySAL: Python Spatial Analysis Library Meta-Package

Python Spatial Analysis Library PySAL, the Python spatial analysis library, is an open source cross-platform library for geospatial data science with

Python Spatial Analysis Library 1.1k Dec 18, 2022
This is a simple python code to get IP address and its location using python

IP address & Location finder @DEV/ED : Pavan Ananth Sharma Dependencies: ip2geotools Note: use pip install ip2geotools to install this in your termin

Pavan Ananth Sharma 2 Jul 05, 2022
Mmdb-server - An open source fast API server to lookup IP addresses for their geographic location

mmdb-server mmdb-server is an open source fast API server to lookup IP addresses

Alexandre Dulaunoy 67 Nov 25, 2022
This GUI app was created to show the detailed information about the weather in any city selected by user

WeatherApp Content Brief description Tools Features Hotkeys How it works Screenshots Ways to improve the project Installation Brief description This G

TheBugYouCantFix 5 Dec 30, 2022
Daily social mapping project in November 2021. Maps made using PyGMT whenever possible.

Daily social mapping project in November 2021. Maps made using PyGMT whenever possible.

Wei Ji 20 Nov 24, 2022
User friendly Rasterio plugin to read raster datasets.

rio-tiler User friendly Rasterio plugin to read raster datasets. Documentation: https://cogeotiff.github.io/rio-tiler/ Source Code: https://github.com

372 Dec 23, 2022