Zonal Statistics | ArcGIS REST APIs

Zonal Statistics

URL:
https://<root>/<serviceName>/RasterAnalysisTools/GPServer/zonal-statistics
Methods:
GET
Version Introduced:
11.3

Description

Summarize Raster Within diagram

The ZonalStatistics task summarizes the cells of a raster within the boundaries of zones defined by another dataset.

ZonalStatistics uses two layers, one that defines specific zones and another that defines the value of each location across the whole area, and calculates summary statistic for the values that fall within each particular area. The layer that defines the areas, inputZoneRasterOrFeatures, is a raster or feature dataset that defines the boundaries of each zone for which a summary values will be calculated. If the zone layer is a raster, it must have an integer data type. If the zone is a feature layer, it can contain overlapping polygons, where the zonal analysis will not be performed for each individual feature. Since the feature input is converted to a raster, each location can have only one value. The area defining the values, inputValueRaster, is a raster dataset that records the value of a particular property at each location.

The statistic can report such properties as the sum of all the values in each area, the maximum value, or the average value. The statisticType value can be calculated based on a mathematical function, the result of a sorting operation on the values, or an indication of the frequency values.

The following are example applications of ZonalStatistics:

  • Calculate the total acreage of land-use type for each watershed when given a layer of watershed boundaries and a layer of land-use boundaries by land-use type.
  • Summarize the average value of vacant parcels within each city boundary when given a layer of parcels in a county and a layer of city boundaries.

Request parameters

ParameterDetails

inputZoneRasterOrFeatures (Required)

The layer that defines the boundaries of the zones.

Syntax: This parameter can have either a raster input or a feature input. For raster input, this parameter can be specified as a portal item ID, a URL to a raster image service layer, a cloud raster dataset, or a shared raster dataset. For feature input, this parameter can be specified as either a URL to a feature service layer or a feature collection.

Raster input examples:

Use dark colors for code blocksCopy
1
2
3
4
//Portal item as input raster
"inputZoneRasterOrFeatures":{"itemId": <portal item Id>}
//URL as input raster
"inputZoneRasterOrFeatures":{"url": <image service layer url>}

Feature input examples:

Use dark colors for code blocksCopy
1
2
3
4
//Feature layer URL
"inputZoneRasterOrFeatures":{"url": <feature service layer url>}
//Feature collection
"inputZoneRasterOrFeatures":{"layerDefinition": {}, "featureSet": {}}

zoneField (Required)

A field on the inputZoneRasterOrFeatures value that contains the values that define each zone.

It can be an integer or a string field of the zone dataset.

Example:

Use dark colors for code blocksCopy
1
"zoneField": ParcelID

inputValueRaster (Required)

The raster layer that will be summarized by the zones defined by the inputZoneRasterOrFeatures value.

Syntax: This parameter can be specified as a portal item ID, a URL to a raster image service layer, a cloud raster dataset, or a shared raster dataset.

Examples:

Use dark colors for code blocksCopy
1
2
3
4
//Portal item as input raster to summarize
"inputValueRaster":{"itemId": <portal item Id>}
//URL as input raster to summarize
"inputValueRaster":{"url": <image service layer url>}

outputName (Required)

The name of the output image service that will be created.

You can specify the name, or you can create an empty service using Portal Admin Sharing API and use the return JSON object as input to this parameter.

Syntax: A JSON object describes the name of the output or the output raster.

Output name example:

Use dark colors for code blocksCopy
1
"outputName":{"serviceProperties":{"name":"testrasteranalysis"}}

Output raster examples:

Use dark colors for code blocksCopy
1
2
3
4
5
6
7
8
9
10
11
12
//Output portal item:
"outputName":{"itemId": <portal item id>}

//Output url:
"outputName":{"url": <image service url}

//Output raster layer service:
"outputName":{"serviceProperties":
  {"name":"testrasteranalysis",
    "serviceUrl":"https://<server name>/server/rest/services/Hosted/testrasteranalysis/ImageServer"},
  "itemProperties":{"itemId":"8cfbd3ec25584d0d8f4ed23b8ff7c43b","folderId":"sdfwerfbd3ec25584d0d8f4"}
}

statisticType (Optional)

The statistical summary type that will be calculated for the cells within each zone of the feature in the inputValueRaster value.

Syntax: The input can be one of the following:

  • MEAN—Calculates the average of all cells in the value raster that belongs to the same zone as the output cell. This is the default.
  • MAJORITY —Determines the majority value of all cells in the value raster that belongs to the same zone as the output cell.

  • MAJORITY_COUNT—The frequency of all cells that contain the majority value in the value raster that belong to the same zone as the output cell will be calculated.
  • MAJORITY_PERCENT—The percentage of cells that contain the majority value in the value raster that belong to the same zone as the output cell will be calculated.
  • MAXIMUM —Determines the largest value of all cells in the value raster that belongs to the same zone as the output cell.

  • MEDIAN —Finds the median value of all cells in the value raster that belongs to the same zone as the output cell.

  • MINIMUM —Finds the smallest value of all cells in the value raster that belongs to the same zone as the output cell.

  • MINORITY —Determines the minority value of all cells in the value raster that belongs to the same zone as the output cell.

  • MINORITY_COUNT—The frequency of all cells that contain the minority value in the value raster that belong to the same zone as the output cell will be calculated.
  • MINORITY_PERCENT—The percentage of cells that contain the minority value in the value raster that belong to the same zone as the output cell will be calculated.
  • PERCENTILE—Calculates a percentile of all cells in the value raster that belong to the same zone as the output cell. The 90th percentile is calculated by default. You can specify other values (from 0 to 100) using the percentileValues parameter.
  • RANGE —Finds the range of all cells in the value that belongs to the same zone as the output zone.

  • SUM —Adds the total value of all cells in the value raster that belongs to the same zone as the output cell.

  • STD —Finds the standard deviation of all cells in the value raster that belongs to the same zone as the output cell.

  • VARIETY —Finds the variety of all cells in the value raster that belongs to the same zone as the output cell.

If the inputValueRaster value is floating-point type, the zonal calculations for MAJORITY, MINORITY, and VARIETY cannot be computed.

Example:

Use dark colors for code blocksCopy
1
"statisticType": "SUM"

percentileValue (Optional)

Specifies the percentile value to calculate. The default is 90, for the 90th percentile.

The values can range from 0 to 100. The 0th percentile is essentially equivalent to the minimum statistic, and the 100th percentile is equivalent to the maximum. A value of 50 will produce approximately the same result as the median statistic.

This parameter is only supported if the statisticsType parameter is set to PERCENTILE.

Syntax: A Double value that can range from 0 to 100.

Example:

Use dark colors for code blocksCopy
1
"percentileValue": 25

percentileInterpolationType (Optional)

Specifies the method of percentile interpolation to be used when the number of values from the input raster to be calculated is even.

  • AUTO_DETECT —If the input value raster is of integer pixel type, the NEAREST method is used. If the input value raster is of floating-point pixel type, the LINEAR method is used. This is the default.

  • NEAREST —The nearest available value to the desired percentile is used.
  • LINEAR —The weighted average of the two surrounding values from the desired percentile is used.

Example:

Use dark colors for code blocksCopy
1
"percentileInterpolationType": NEAREST

circularCalculation (Optional)

Specifies how the statistics type will be calculated.

Syntax: A Boolean value as either true or false .

  • A value of true specifies that the task calculates circular statistics that are appropriate for cyclic quantities, such as compass direction in degrees, times of day, and fractional parts of real numbers.

  • A value of false specifies that the task calculates arithmetic statistics. This is the default.

Example:

Use dark colors for code blocksCopy
1
"circularCalculation": true

circularWrapValue (Optional)

Specifies the highest possible value (upper bound) in the cyclic data. It is a positive number, with a default value of 360. This value also represents the same quantity as the lowest possible value (lower bound).

This parameter is applicable only when circular statistics are calculated.

ignoreNodata (Optional)

Specify whether NoData in the raster layer to summarize will influence the results of the areas they fall within.

Syntax: A Boolean value as either true or false .

  • A value of true specifies that, within any particular area, only cells that have a value in the raster layer being summarized will be used in determining the output value for that area. Any missing or NoData cells will be ignored in the statistics calculations. This is the default.

  • A value of false specifies that, within any particular area, if any cells in the raster layer do not have a value, it is deemed that there is insufficient information to perform statistical calculations for all the cells in that zone. As a result, the entire zone will receive the NoData value on the output raster.

Example:

Use dark colors for code blocksCopy
1
"ignoreNodata": true

processAsMultidimensional (Optional)

Specifies how the input rasters will be processed if they are multidimensional.

Syntax: A Boolean value as either true or false .

  • A value of true specifies that statistics will be calculated for all dimensions (such as time or depth) of a multidimensional dataset.

  • A value of false specifies that statistics will be calculated from the current slice of a multidimensional dataset. This is the default.

Example:

Use dark colors for code blocksCopy
1
"processasMultidimensional": true

context (Optional)

Contains additional settings that affect task processing. This task has the following settings:

  • Extent (extent )—A bounding box that defines the analysis area.

  • Output Spatial Reference (outSR )—The output raster will be projected into the output spatial reference.

  • Snap Raster (snapRaster )—The output raster will have its cells aligned with the specified snap raster.

  • Cell Size (cellSize )—The output raster will have the resolution specified by cell size.

  • Mask (mask)—Only cells that fall within the analysis mask will be considered in the operation.

f

The response format. The default response format is html .

Values: html | json | pjson

Response

When you submit a request, the task assigns a unique job ID for the transaction.

Use dark colors for code blocksCopy
1
2
3
4
{
  "jobId": "<unique job identifier>",
  "jobStatus": "<job status>"
}

After the initial request is submitted, you can use the jobId to periodically check the status of the job and messages as described in Checking job status. Once the job has successfully completed, you use the jobId to retrieve the results. To track the status, you can make a request of the following form:

Use dark colors for code blocksCopy
1
https://<raster analysis tools url>/ZonalStatistics/jobs/<jobId>

When the status of the job request is esriJobSucceeded , you can access the results of the analysis by making a request of the following form:

Use dark colors for code blocksCopy
1
https://<raster analysis tools url>/ZonalStatistics/jobs/<jobId>/results/outputRaster

Example usage

Below is a sample request URL for ZonalStatistics.

Use dark colors for code blocksCopy
1
https://services.myserver.com/arcgis/rest/services/System/RasterAnalysisTools/GPServer/ZonalStatistics/submitJob

JSON Response syntax

The response returns the outputRaster output parameter, which has properties for parameter name, data type, and value. The content of value is always the output raster dataset itemId and the image service URL.

Use dark colors for code blocksCopy
1
2
3
4
5
6
7
8
{
  "paramName": <parameter name>,
  "dataType": "GPString",
  "value": {
    "itemId": <item Id>,
    "url": <URL>
  }
}

JSON Response example

Use dark colors for code blocksCopy
1
2
3
4
5
6
7
8
{
  "paramName": "outRaster",
  "dataType": "GPString",
  "value": {
    "itemId": "f121390b85ef419790479fc75b493efd",
    "url": "https://<server name>/arcgis/rest/services/Hosted/<service name>/ImageServer"
  }
}

Your browser is no longer supported. Please upgrade your browser for the best experience. See our browser deprecation post for more details.