Доступно с лицензией Spatial Analyst.
Краткая информация
Определяет взаимосвязь между фактором вертикальной стоимости и вертикальным относительным углом перемещения с помощью линейной функции.
Иллюстрация
Обсуждение
Этот объект используется в инструментах Накопление расстояния и Распределение по расстоянию Spatial Analyst, а также в устаревших инструментах расстояния Путевое расстояние, Распределение по путевому расстоянию и Путевое направление.
Объект вертикальный фактор (VF) определяет отношение между вертикальным фактором стоимости и вертикальным относительным углом движения (VRMA).
VF определяет вертикальную трудность, возникающую при переходе от одной ячейки к другой.
VRMA определяет угол наклона между ячейкой ОТ или обрабатываемой ячейкой и ячейкой ДО.
В системе координат VRMA-VF вертикальные факторы определяются прямой линией. Линия пересекает ось y, соответствующую VF, в точке со значением, связанным с zeroFactor. Угол наклона линии может быть задан с применением аргумента slope.
Синтаксис
VfLinear ({zeroFactor}, {lowCutAngle}, {highCutAngle}, {slope})
Параметр | Описание | Тип данных |
zeroFactor | Фактор zeroFactor будет использоваться для определения местоположения точки пересечения с осью y для линейной функции. (Значение по умолчанию — 1.0) | Double |
lowCutAngle | Значение VRMA в градусах, определяющее нижний порог, ниже которого значения VF устанавливаются равными бесконечности. (Значение по умолчанию — -90.0) | Double |
highCutAngle | Значение VRMA в градусах, определяющее верхний порог, выше которого значения VF устанавливаются равными бесконечности. (Значение по умолчанию — 90.0) | Double |
slope | Определяет уклон прямой линии в системе координат "VRMA-VF". Значение уклона задается в виде подъема/протяженности. Например, 30-градусный уклон обозначается 1/30, задается в виде 0,03333 (подъем/протяженность: 1 вертикальный фактор VF по оси y / 30 градусов по оси x); 90-градусный уклон обозначается 0,011111. (Значение по умолчанию — 0.011111) | Double |
Свойства
Свойство | Описание | Тип данных |
zeroFactor (чтение и запись) | Нулевой фактор zeroFactor будет использоваться для определения местоположения точки пересечения с осью y для класса вертикального фактора. | Double |
lowCutAngle (чтение и запись) | Значение VRMA в градусах, определяющее нижний порог, ниже которого значения VF устанавливаются равными бесконечности. | Double |
highCutAngle (чтение и запись) | Значение VRMA в градусах, определяющее верхний порог, выше которого значения VF устанавливаются равными бесконечности. | Double |
slope (чтение и запись) | Определяет уклон прямой линии в системе координат "VRMA-VF". Значение уклона задается в виде подъема над протяженностью. Например, 30-градусный уклон обозначается 1/30, задается в виде 0,03333 (подъем/протяженность: 1 вертикальный фактор VF по оси y / 30 градусов по оси x); 90-градусный уклон обозначается 0,011111. | Double |
Пример кода
Иллюстрирует создание класса VfLinear и его использование в инструменте DistanceAccumulation в окне Python.
import arcpy
from arcpy import env
from arcpy.sa import *
env.workspace = "C:/sapyexamples/data"
myVerticalFactor = VfLinear(1.0, -90.0, 90.0, 0.01111)
outDistAccum = DistanceAccumulation("Source.shp", "", "elev.tif",
"cost.tif", "elev.tif",
myVerticalFactor)
outDistAccum.save("C:/sapyexamples/output/distAccumVfL.tif")
Выполняет анализ DistanceAccumulation с использованием класса VfLinear.
# Name: VfLinear_Ex_02.py
# Description: Uses the VfLinear object to run the
# DistanceAccumulation tool
# 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
inSourceData = "source.shp"
inCostRaster = "costraster.tif"
inElevation = "elev.tif"
# Create the VfLinear Object
zeroFactor = 1.0
lowCutAngle = -90
highCutAngle = 90
slope = 0.01111
myVerticalFactor = VfLinear(zeroFactor, lowCutAngle, highCutAngle, slope)
# Check out the ArcGIS Spatial Analyst extension license
arcpy.CheckOutExtension("Spatial")
# Execute PathDistance
outDistAccum = DistanceAccumulation(inSourceData, "", inElevation,
inCostRaster, inElevation,
myVerticalFactor)
# Save the output
outDistAccum.save("C:/sapyexamples/output/distaccumvfL2.tif")