v3_Tool Pedestrian Access and Availability - USEPA/ATtILA2 GitHub Wiki

Pedestrian Access and Availability

Available with Spatial Analyst license.

Summary

Estimates the availability of parkland per person based on accessibility of parkland. Accessibility is determined using walkable routes along a cost surface raster and a user-specified maximum travel distance. The output is a raster.

Optionally, park polygons which abut or overlap each other can be dissolved into a single unit if no physical barrier to movement is known to exist before determining accessibility and availability.

Usage

  • This tool processes all polygons in the Reporting unit feature regardless of selections set. The ability to limit calculations to only selected reporting unit polygons is not supported in this release.

  • NOTE: For the most accurate results and shortest processing times, it is highly recommended that all input layers be in the same spatial reference.

  • NOTE: Enabling the Parallel Processing Factor environment can improve computation time for several ATtILA tools, but we have detected, on rare occasions, doing so can lead to spurious results. As a precaution, ATtILA will disable the Parallel Processing Factor environment for this tool. We hope to return this choice to the user once the impact on operational speed and accuracy of swapping geoprocessing tools with their pairwise counterparts has been assessed.

  • This tool performs the following steps for each individual park:

    • Select park by its id value and create a feature layer
    • Create a buffer around the park extending 5% beyond the maximum travel distance
    • Create Cost Distance raster to the Maximum travel distance with the buffer area as the processing extent
    • Designate the accessible area by setting all cell values to 1 for any cell in the Cost Distance raster with a value >= 0
    • Expand the accessible area if indicated by the Expand area served parameter
    • Determine Population within accessible area
      • if Population parameter is a raster:
        1. Set the geoprocessing snap raster and processing cell size environments to match the population raster
        2. Zonal Statistics As Table with the SUM option is used to calculate the surrounding population
      • if Population parameter is a polygon feature:
        1. the accessible area raster is converted to a polygon
        2. Tabulate Intersection is used with this polygon and the Population polygon feature to get an area-weighted estimate of the surrounding population
    • Determine Availability (Cost distance value to park area divided by surrounding population)
  • The Reporting unit feature is a zone dataset.

    • A zone is defined as all areas in the input that have the same value. The areas do not have to be contiguous. The term "value" in this definition refers to the unique values in the Reporting unit ID field. Therefore, all polygons with the same reporting unit ID are treated as a single zone.

    • When more than one polygon has the same reporting unit ID, the areas for each polygon are combined and metrics are reported as a single record in the Output table.

  • As the Reporting unit feature is a vector dataset, ArcGIS will perform a vector to raster conversion during processing.

    • To better control the vector to raster conversion, the tool defaults the Snap raster and the Processing cell size to that of the Land cover grid. These may be changed from within the tool.

    • If a large size disparity exists between the extents of the Reporting unit feature and the Land cover grid, the user may wish to set the Extent in Environment Settings > Processing Extent to the smaller of the two to avoid unnecessary processing.

  • If the Reporting unit feature has overlapping features, the zonal analysis will be performed for each individual feature.

  • If a feature in the Reporting unit feature zone data does not overlap any cell centers in the secondary class rasters (e.g.,Land cover grid), those zones will not get converted to the internal zone raster. As a result, those zones will not be represented in the Output table.

  • The Population raster or polygon feature will allow you to choose either a raster, or a polygon feature.

    • When choosing a raster, this tool assumes the grid cell value to be the population count for the grid cell.

    • When choosing a polygon feature, this tool assumes that population is distributed evenly throughout each feature polygon. The tool apportions population by area weighting. For example, if 50% of a population polygon is within a reporting unit, the tool will assign 50% of the value in the polygon's Population field to that reporting unit. Caution should be exercised when population polygons do not have even population distributions as this could result in an overweighting or underweighting of population when the tool performs the apportionment. Generally, greater accuracy will be achieved if the population polygons are smaller than the smallest Reporting unit feature polygons.

    • NOTE: The Population field dropdown is only available when the Population raster or polygon feature is a polygon feature.

    • NOTE: The Population field will default to 'Value' when the Population raster or polygon feature is an integer grid.

    • NOTE: The Population field will be empty when the Population raster or polygon feature is a non-integer grid.

  • Final output is written to the location specified in the Output raster parameter. The Output raster may be saved in a file folder or a geodatabase.

    • NOTE: For most consistent results, It is highly recommended that tool output be saved to a file geodatabase.

    • When saving in a File Geodatabase, no extension is permitted for the Output raster name.

    • When saving in a file folder, the following extensions are allowed for the Output raster name:

      • .img for ERDAS IMAGINE

      • .tif for TIFF

      • No extension for Esri Grid

  • Field names in the Output table follow this naming scheme:

    • [class lcpField] or p[class Id] - The percent of the non-excluded reporting unit occupied by the land cover class.
  • In Additional Options, the user may elect to 'Retain Intermediate Layers Generated During Metric Processing', and/or 'Record Process Steps Taken During Metric Calculation'.

    • Retain Intermediate Layers Generated During Metric Calculation

      • Choosing INTERMEDIATES retains several of the key intermediate products (e.g., rasters, feature classes, tables) used to generate the final tool output. By examining the intermediate products, the user can gain a better understanding how the metric is calculated. The following intermediate products are listed in the general order they are generated:

        • paaa_Parks_# (vector) - A copy of the Park feature with three additional fields: CalcAreaM2, Pop_Access, and SQM_Avail.

          • CalcAreaM2 - The area (m²) per person of the land cover class by reporting unit.

          • Pop_Access -

          • SQM_Avail -

        • NOTE: To ensure unique filenames, intermediate filenames are typically generated using the CreateScratchName ArcPy function. This function provides a unique name for the intermediate product by appending a number to a filename prefix. The number starts at 0 and is incremented until a unique filename for the output workspace is found. The generated number is represented in this manual by the hashtag (#) symbol.

        • NOTE: The appended number may not be the same for all intermediate products saved during a tool run. Running a tool with different input options can result in different intermediate products being produced. If a tool is run more than once using the same output workspace, different number suffixes may be generated depending on the files already present in the output workspace.

      • Intermediate products are saved to one of the following locations:

        • When the Output table is saved as a File Geodatabase Table, intermediate products are placed in the same file geodatabase.

        • When the Output table is saved as a dBASE Table, a file geodatabase named "attilaScratchWorkspace" is automatically generated in the same output location specified for the Output table. Intermediate products are placed in the attilaScratchWorkspace file geodatabase.

        • NOTE: ATtILA will report the location of the saved intermediate products in the Tool Details' Messages section.

    • Record Process Steps Taken During Metric Calculation

      • Choosing LOGFILE will generate a text file containing information on system setup, tool inputs, parameter selections, script operations, and any encountered error or warning messages.

      • Log files will be named, [Output table]_[date_time].txt, with the date represented as YYYYMMDD and time as hh_mm_ss.

      • Where the log file is saved is dependent on the Current Workspace environment setting:

        • When the Current Workspace is a geodatabase, the log file will be located in the folder that contains that workspace.

        • When the Current Workspace is a folder, the log file will be located in that folder.

        • NOTE: In ArcGIS Pro, the default value for the Current Workspace environments is the project default geodatabase.

        • NOTE: ATtILA will report the name and location of the log file in the Tool Details' Messages section.

Syntax

PAAA (Park_feature, {Dissolve_parks}, Cost_surface_raster, Population_raster_or_polygon_feature, {Population_field}, Maximum_travel_distance, Expand_area_served, Output_raster, {Processing_cell_size}, {Snap_raster}, {Select_options})

Parameter Explanation Data Type
Park_feature The vector polygon dataset that defines the reporting units. Feature Layer
Dissolve_parks (Optional) Specifies whether park features that overlap or share a boundary should be dissolved into a single feature before calculating accessibility and availability.

  • false - Park features that overlap or share a boundary will not be dissolved. This is the default.
  • true - Park features that overlap or share a boundary will be dissolved into a single feature before calculating accessibility and availability.
Boolean
Cost_surface_raster A raster with weighted values that represent the relative walkability of each pixel. Users can provide their own cost surface raster or build one with the ATtILA Create Walkability Cost Raster Utility.

The input must be an integer raster layer.
Population_raster_or_polygon_feature The raster or vector polygon dataset that contains population data. Feature Layer or Raster Layer
Population_field (Optional) The field in the Population raster or polygon feature layer that contains population data.

The behavior of this parameter is dependent on the input for the Population or polygon feature:

  • The field selection dropdown is available when the input is a polygon feature.
  • The field selection will default to 'Value' when the input is an integer grid.
  • The field selection will be empty when the input is a non-integer grid.
Field
Maximum_travel_distance The maximum accumulated distance along the cost surface raster that is within the user defined walking distance of the park feature.

The input must be an integer value.
Long
Expand_area_served The number of pixels the resulting service area will be expanded to produce the final park service area. This is useful to fill in gaps in service areas and to account for possible underestimation of length when measured from a lower resolution raster.

The service area will be expanded in all directions by this value regardless of the corresponding cost surface raster values or maximum travel distance values.

This value must be an integer greater than or equal to zero.
Long
Output_raster The output accessibility and availability raster.

It is always a floating point raster.
Raster Dataset
Processing_cell_size (Optional) The Processing cell size for the Output raster.

The default Processing cell size is the cell size of the input Cost surface raster. Optionally, the user may select a different cell size.
Analysis cell size
Snap_raster (Optional) The raster that the cell alignment of the Output raster will be aligned to.

The default Snap raster is the Cost surface raster.
Raster Layer
Select_options Tool options available to provide additional information:

  • Retain Intermediate Layers Generated During Metric Calculation - Saves key intermediate products (e.g., rasters, feature classes, tables) used to generate the final tool output.
  • Record Process Steps Taken During Metric Calculation - Saves a log file containing information on tool inputs, selections, and operations.
Multiple Value

Code Samples

Pedestrian Access and Availability example 1 (Python window)

This example returns a raster. The options to retain the intermediate calculation products, and to record the process steps into a log file have also been selected.

import arcpy
from arcpy.sa import *
arcpy.ImportToolbox(r"D:\Destination Folder\ATtILA v{#}.tbx")

Park_feature = "D:\\pyexamples\\data.gdb\\Parks"
Dissolve_parks = "false"
Cost_surface_raster = "D:\\pyexamples\\data.gdb\\Walkable_Cost_Surface"
Population_raster_or_polygon_feature = "D:\\pyexamples\\data.gdb\\DASY_Population"
Population_field = ""
Maximum_travel_distance = "800"
Expand_area_served = "8"
Output_raster = "D:\\pyexamples\\results.gdb\\ParksEval_PAAA"
Processing_cell_size = "10"
Snap_raster = "D:\\pyexamples\\data.gdb\\Walkable_Cost_Surface"
Select_options = "'INTERMEDIATES  -  Retain Intermediate Layers Generated During Metric Calculation';'LOGFILE  -  Record Process Steps Taken During Metric Calculation'" 

arcpy.ATtILA.PAAA(
                  Park_feature,
                  Dissolve_parks,
                  Cost_surface_raster,
                  Population_raster_or_polygon_feature,
                  Population_field,
                  Maximum_travel_distance,
                  Expand_area_served,
                  Output_raster,
                  Processing_cell_size,
                  Snap_raster,
                  Select_options
                  )

Pedestrian Access and Availability example 2 (Tool Details Messages)

This is a sample capture of the geoprocessing messages generated during a typical tool run. It is provided here to assist in the understanding of the tool's processing steps.


Start Time: Day, Month DD, YYYY hh:mm:ss AM/PM
Created log file: workspace path\\filename
Started: YYYY-MM-DD hh:mm:ss Setting up environment variables
Intermediates are stored in this directory: workspace path
[YYYY-MM-DD hh:mm:ss] Using Walkable_Cost_Surface's extent for geoprocessing steps.
[YYYY-MM-DD hh:mm:ss] Using Walkable_Cost_Surface's spatial reference for geoprocessing steps: Albers_Conical_Equal_Area
[YYYY-MM-DD hh:mm:ss] Creating temporary copy of Parks. Intermediate: paaa_Parks_0
[YYYY-MM-DD hh:mm:ss] Collecting id values from OBJECTID_1 for each park
[YYYY-MM-DD hh:mm:ss] Calculating park area in square meters
[YYYY-MM-DD hh:mm:ss] Calculating access and availability for 20 areas
The following steps are performed for each park:
            1) Select park by its id value and create a feature layer
            2) Create a buffer around the park extending 5% beyond the maximum travel distance
            3) Create Cost Distance raster to the Maximum travel distance with the buffer area as the processing extent
            4) Designate the accessible area by setting all cell values to 1 for any cell in the Cost Distance raster with a value >= 0
            5) Expand the accessible area if indicated by the Expand area served parameter
            6) Determine Population within accessible area
                a) if Population parameter is a raster:
                    1) Set the geoprocessing snap raster and processing cell size environments to match the population raster 
                    2) Zonal Statistics As Table with the SUM option is used to calculate the surrounding population
                b) if Population parameter is a polygon feature:
                    1) the accessible area raster is converted to a polygon
                    2) Tabulate Intersection is used with this polygon and the Population polygon feature to get 
                       an area-weighted estimate of the surrounding population
            7) Determine Availability (Cost distance value to park area divided by surrounding population)
[YYYY-MM-DD hh:mm:ss] Starting calculations per park...
2 out of 20 loops, 10.0% complete, 0:00:29 elapsed, est. 0:04:21 remaining, average time per loop: 0:00:14
4 out of 20 loops, 20.0% complete, 0:01:10 elapsed, est. 0:04:40 remaining, average time per loop: 0:00:17
6 out of 20 loops, 30.0% complete, 0:01:51 elapsed, est. 0:04:19 remaining, average time per loop: 0:00:18
8 out of 20 loops, 40.0% complete, 0:02:32 elapsed, est. 0:03:48 remaining, average time per loop: 0:00:19
10 out of 20 loops, 50.0% complete, 0:03:12 elapsed, est. 0:03:12 remaining, average time per loop: 0:00:19
12 out of 20 loops, 60.0% complete, 0:03:53 elapsed, est. 0:02:35 remaining, average time per loop: 0:00:19
14 out of 20 loops, 70.0% complete, 0:04:34 elapsed, est. 0:01:57 remaining, average time per loop: 0:00:19
16 out of 20 loops, 80.0% complete, 0:05:15 elapsed, est. 0:01:18 remaining, average time per loop: 0:00:19
18 out of 20 loops, 90.0% complete, 0:05:55 elapsed, est. 0:00:39 remaining, average time per loop: 0:00:19
20 out of 20 loops, 100.0% complete, 0:06:42 elapsed, est. 0:00:00 remaining, average time per loop: 0:00:20
[YYYY-MM-DD hh:mm:ss] Finished last park
[YYYY-MM-DD hh:mm:ss] Merging 20 calculated park/population rasters. Output: ParksEval_PAAA.
[YYYY-MM-DD hh:mm:ss] Deleting individual park rasters...
[YYYY-MM-DD hh:mm:ss] Individual park rasters deletion complete
Log file closed
Succeeded at Day, Month DD, YYYY hh:mm:ss AM/PM (Elapsed Time: ##.## units)

Tags

There are no tags for this item.

Credits

There are no credits for this item.

Use Limitations

There are no access and use limitations for this item.


arrow_up Top of the page     |     arrow_left Land Cover Coefficient Calculator     |     arrow_right Population Density Metrics


⚠️ **GitHub.com Fallback** ⚠️