Disponible con una licencia de Spatial Analyst.
Resumen
Calcula el origen más cercano para cada celda en función del menor coste acumulativo sobre una superficie de coste.
Más información sobre el funcionamiento de las herramientas de Distancia de coste
Ilustración
Uso
Los datos de origen de entrada pueden ser un ráster o una clase de entidad.
Cuando los datos de origen de entrada son un ráster, el conjunto de celdas de origen consta de todas las celdas del ráster de origen que tengan valores válidos. Las celdas con valores NoData no se incluyen en el conjunto de origen. El valor 0 se considera un origen legítimo. Se puede crear fácilmente un ráster de origen mediante las herramientas de extracción.
Cuando los datos de origen de entrada son una clase de entidad, las ubicaciones de origen se convierten internamente en un ráster antes de realizar el análisis. La resolución del ráster se puede controlar con el entorno Tamaño de celda. De forma predeterminada, la resolución se establece como la resolución del ráster de coste de entrada.
Al utilizar datos de entidad poligonal para los datos de origen de entrada, se debe tener cuidado con la manera en que el tamaño de celda de salida se maneja cuando es grueso en relación con los detalles presentes en la entrada El proceso de rasterización interno emplea el mismo método Tipo de asignación de celda predeterminado que la herramienta De polígono a ráster, que es CELL_CENTER. Esto significa que los datos no ubicados en el centro de la celda no se incluirán en la salida de origen rasterizada intermedia, y por lo tanto no se representan en los cálculos de distancia. Por ejemplo, si sus orígenes son una serie de polígonos pequeños, como huellas de edificios, que son pequeñas en relación con el tamaño de la celda de salida, es posible que solo algunos de ellos caigan debajo de los centros de las celdas ráster de salida, ocasionando aparentemente que la mayor parte de los otros se pierdan en el análisis.
Para evitar esta situación, como un paso intermedio, puede rasterizar las entidades de entrada directamente con la herramienta Polígono a ráster y establecer un campo de Prioridad, y utilizar la salida resultante como entrada para la herramienta de distancia. Alternativamente, puede seleccionar un tamaño de celda lo suficientemente pequeña para capturar la cantidad adecuada de detalle de las entidades de entrada.
Para calcular la asignación, las ubicaciones de origen pueden tener un valor asociado, que se puede especificar mediante el parámetro Campo fuente. Si el origen de entrada es un ráster entero, el campo predeterminado es VALUE. Si es una entidad, será el primer campo entero de la tabla de atributos. Si los datos de origen de entrada son un ráster de punto flotante, se debe especificar un parámetro de ráster de valor entero.
Cuando la entrada de la fuente es una entidad, de manera predeterminada, se utilizará el primer campo disponible válido. Si no existen campos válidos, se utilizará el campo ObjectID (por ejemplo, OID o FID, dependiendo del tipo de entrada de entidad).
Las ubicaciones de las celdas NoData en el Ráster de entrada de costes actúan como barreras en las herramientas de superficie de costes. Cualquier ubicación de celdas a la que se le asigne NoData en la superficie de costes de entrada recibirá NoData en todos los rásteres de salida (coste de distancia, asignación y vínculo anterior).
Si los datos de origen de entrada y el ráster de costes son extensiones diferentes, la extensión de salida predeterminada es la intersección de los dos. Para obtener una superficie de distancia de costes para toda la extensión, seleccione la opción Combinación de entradas de la configuración del entorno de salida Extensión.
Si se ha establecido una Máscara en el entorno, todas las celdas con máscara se tratarán como valores NoData.
Cuando se ha definido una máscara en la ventana Análisis ráster y las celdas que serán enmascaradas crearán una máscara en el origen, los cálculos ocurrirán en las celdas de origen restantes. Las celdas de origen con máscaras no se considerarán en los cómputos. Las ubicaciones de estas celdas se asignarán como NoData en todos los rásteres de salida (distancia, asignación y vínculo anterior).
El Ráster de valor de entrada resulta útil cuando se utilizan zonas o valores alternativos o si el origen se deriva de una operación que genera un resultado binario de 0 o 1, y por lo tanto pierde los valores de zona originales asociados con estas ubicaciones. El ráster de valor puede restaurar estos valores o permitir el análisis de combinaciones adicionales de valores de zona dentro de las ubicaciones del origen.
Si se utiliza el ráster de valor, puede cambiar la configuración y los resultados de la salida de asignación de costes pero no afectará los resultados de distancia de coste opcional ni los del vínculo.
La Distancia máxima se especifica en las mismas unidades de coste que las del ráster de costes.
En el ráster de distancia de salida, la distancia de menor coste (o distancia de coste acumulativo mínimo) de una celda a un conjunto de ubicaciones de origen es el límite más bajo de las distancias de menor coste desde la celda hasta todas las ubicaciones de origen.
Las características del origen, o los elementos que se mueven desde un origen, se pueden controlar mediante el Multiplicador del coste en origen (el modo de viaje o la magnitud en el origen), el Coste de inicio en origen (el coste inicial antes de que empiece el movimiento), la Tasa de resistencia en origen (cálculo dinámico del ajuste para el impacto del coste acumulado, por ejemplo, simular el cansancio de un senderista) y la Capacidad en origen (qué coste puede asimilar un origen antes de llegar a su límite).
Si alguno de los parámetros de las características de origen se especifica utilizando un valor, ese valor se aplica a todos los orígenes. Si los parámetros se especifican mediante campos asociados al origen, los valores de la tabla se aplicarán de forma exclusiva a los orígenes correspondientes.
Consulte Entornos de análisis y Spatial Analyst para obtener detalles adicionales sobre los entornos de geoprocesamiento válidos para esta herramienta.
Sintaxis
CostAllocation (in_source_data, in_cost_raster, {maximum_distance}, {in_value_raster}, {source_field}, {out_distance_raster}, {out_backlink_raster}, {source_cost_multiplier}, {source_start_cost}, {source_resistance_rate}, {source_capacity})
Parámetro | Explicación | Tipo de datos |
in_source_data | Ubicaciones de origen de entrada. Esto es un dataset de entidades o ráster que identifica las celdas o las ubicaciones para las cuales se calcula la distancia de menor coste acumulado de cada ubicación de celda de salida. Para los rásteres, el tipo de entrada puede ser de tipo entero o punto flotante. Si el ráster de origen de entrada es de punto flotante, debe establecerse el {in_value_raster} y debe ser del tipo entero. El ráster de valores tendrá prioridad sobre cualquier configuración del {source_field}. | Raster Layer | Feature Layer |
in_cost_raster | Ráster que define la impedancia o el coste de hacer un movimiento planimétrico por medio de cada celda. El valor de cada ubicación de celda representa la distancia de coste por unidad para moverse a través de la celda. Cada valor de ubicación de celda se multiplica por la resolución de la celda mientras que también se compensa por el movimiento diagonal para obtener el coste total de pasar por medio de la celda. Los valores del ráster de coste pueden ser enteros o de punto flotante, pero no pueden ser negativos o cero (no puede tener un coste negativo o cero). | Raster Layer |
maximum_distance (Opcional) | Define el umbral que los valores de coste acumulado no pueden superar. Si un valor de distancia de coste acumulado supera este valor, el valor de salida de la ubicación de la celda será NoData. La distancia máxima define la extensión por la cual se calculan las distancias de coste acumulado. La distancia predeterminada es hasta el borde del ráster de salida. | Double |
in_value_raster (Opcional) | Ráster entero de entrada que identifica los valores de la zona que se deben utilizar para cada ubicación de origen de entrada. En cada ubicación de origen (celda o entidad), el valor definido por el {in_value_raster} se asignará a todas las celdas asignadas a la ubicación de origen para el cómputo. El ráster de valores tendrá prioridad sobre cualquier configuración para el {source_field}. | Raster Layer |
source_field (Opcional) | El campo que se utiliza para asignar los valores a las ubicaciones de origen. Debe ser de tipo entero. Si se ha establecido el {in_value_raster}, los valores de esa entrada tendrán prioridad sobre cualquier configuración para el {source_field}. | Field |
out_distance_raster (Opcional) | Ráster de distancia de coste de salida. El ráster de distancia de coste identifica, para cada celda, la menor distancia de coste acumulado sobre una superficie de coste hacia las ubicaciones de origen identificadas. Un origen puede ser una celda, un conjunto de celdas o una o más ubicaciones de entidades. El ráster de salida es de tipo de punto flotante. | Raster Dataset |
out_backlink_raster (Opcional) | Ráster de vínculo anterior de coste de salida. El ráster de vínculo anterior contiene valores de 0 a 8, que definen la dirección o identifican la celda próxima (la celda que sigue) a lo largo de la ruta con menor coste acumulativo desde una celda para alcanzar la fuente de menor coste. Si la ruta es pasar al elemento próximo derecho, se le asignará a la celda el valor 1, 2 para la celda diagonal derecha inferior y continuando en el sentido de las agujas del reloj. El valor 0 se reserva para las celdas de origen. | Raster Dataset |
source_cost_multiplier (Opcional) | Multiplicador que se debe aplicar a los valores de coste. Permite controlar el modo de viaje o la magnitud en un origen. Cuanto mayor sea el multiplicador, mayor será el coste de moverse a través de cada celda. Los valores deben ser mayores que cero. El valor predeterminado es 1. | Double | Field |
source_start_cost (Opcional) | El coste de inicio a partir del cual empezarán los cálculos del coste. Permite especificar el coste fijo asociado a un origen. En lugar de empezar con un coste cero, el algoritmo de coste empezarán con el valor establecido en el source_start_cost. Los valores deben ser mayores o iguales que cero. El valor predeterminado es 0. | Double | Field |
source_resistance_rate (Opcional) | La tasa por la que se multiplicará el coste acumulado para determinar el ajuste de la resistencia. Este parámetro simula el aumento del esfuerzo para sobreponerse a los costes a medida que aumenta el coste acumulado. Se utiliza para modelar el cansancio del viajero. El coste acumulado que aumenta para llegar a una celda se multiplica por la tasa de resistencia y se agrega al coste de moverse a la celda siguiente. Cuando mayor sea la tasa de resistencia, más coste se agregará a la celda siguiente, que se calcula para cada movimiento posterior. Como la tasa de resistencia es similar a una tasa compuesta y normalmente los valores del coste acumulado son muy grandes, es recomendable usar tasas de resistencia pequeñas, como 0,02 o 0,005, o incluso menores, dependiendo de los valores del coste acumulado. Los valores deben ser mayores o iguales que cero. El valor predeterminado es 0. | Double | Field |
source_capacity (Opcional) | Define la capacidad de coste para el viajero desde un origen. Cada origen aumenta hasta la capacidad especificada. Los valores deben ser mayores que cero. La capacidad predeterminada es hasta el borde del ráster de salida. | Double | Field |
Valor de retorno
Nombre | Explicación | Tipo de datos |
out_allocation_raster | El ráster de asignación de costes de salida. Este ráster identifica la zona de cada ubicación de origen (celda o entidad) que se puede alcanzar con el menor coste acumulativo. El ráster de salida no es de tipo entero. | Raster |
Muestra de código
Ejemplo 1 de CostAllocation (ventana de Python)
La siguiente secuencia de comandos de la ventana de Python muestra cómo utilizar la herramienta CostAllocation.
import arcpy
from arcpy import env
from arcpy.sa import *
env.workspace = "C:/sapyexamples/data"
out = ()
costAllocOut = CostAllocation("observers.shp", "costraster", "", "elevation",
"FID", "c:/sapyexamples/output/distout",
"c:/sapyexamples/output/backlinkout", "Multiplier", "StartCost", "Resistance", 500000)
costAllocOut.save("c:/sapyexamples/output/costalloc")
Ejemplo 2 de CostAllocation (secuencia de comandos independiente)
Esta secuencia de comandos utiliza un ráster de costes, una capa de entidades de puntos de origen y varios parámetros opcionales para calcular un ráster de celdas que contiene el valor del origen más cercano.
# Name: CostAllocation_Ex_02.py
# Description: Calculates for each cell its nearest source
# based on the least accumulative cost over a
# cost surface.
# Requirements: Spatial Analyst Extension
# Import system modules
import arcpy
from arcpy import env
from arcpy.sa import *
# Set environment settings
env.workspace = "C:/sapyexamples/data"
# Set local variables
inFeature = "observers.shp"
costRaster = "costraster"
maxDist = ""
valRaster = "elevation"
featField = "FID"
outDistanceRaster = "c:/sapyexamples/output/distout"
outBacklink = "c:/sapyexamples/output/backlinkout"
multiplier = "Multiplier"
startCost = "StartCost"
resistance = "Resistance"
capacity = 500000
# Check out the ArcGIS Spatial Analyst extension license
arcpy.CheckOutExtension("Spatial")
# Execute CostAllocation
costAllocOut = CostAllocation(inFeature, costRaster, maxDist,
valRaster, featField, outDistanceRaster,
outBacklink, multiplier, startCost,
resistance, capacity)
# Save the output
costAllocOut.save("c:/sapyexamples/output/costalloc01")
Entornos
Información sobre licencias
- ArcGIS Desktop Basic: Requiere Análisis espacial
- ArcGIS Desktop Standard: Requiere Análisis espacial
- ArcGIS Desktop Advanced: Requiere Análisis espacial