VfSymLinear

Доступно с лицензией Spatial Analyst.

Краткая информация

Определяет отношение между фактором вертикальной стоимости и вертикальным углом относительного перемещения (VRMA) посредством симметричной линейной функции либо в отрицательной, либо в положительной стороне VRMA, соответственно. Две линейные функции симметричны относительно оси VF (y).

Иллюстрация

Граф вертикального фактора VfSymLinear
Граф симметричного линейного вертикального фактора.

Обсуждение

Этот объект используется в инструментах Накопление расстояния и Распределение по расстоянию Spatial Analyst, а также в устаревших инструментах расстояния Путевое расстояние, Распределение по путевому расстоянию и Путевое направление.

Объект вертикальный фактор (VF) определяет отношение между вертикальным фактором стоимости и вертикальным относительным углом движения (VRMA).

VF определяет вертикальную трудность, возникающую при переходе от одной ячейки к другой.

VRMA определяет угол наклона между ячейкой ОТ или обрабатываемой ячейкой и ячейкой ДО.

Класс VfSymLinear состоит из двух линейных функций по отношению к углам VRMA, которые симметричны относительно оси VF (оси y). Обе линии пересекают ось y в значении VF, связанном с zeroFactor. Уклон линий определяется как единый уклон, задаваемый относительно положительного VRMA с использованием аргумента вертикального фактора slope. Для отрицательных VRMA уклон является зеркальным отражением заданного наклона линии.

Синтаксис

VfSymLinear ({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

Пример кода

VfSymLinear, пример 1 (окно Python)

Иллюстрирует создание класса VfSymLinear и его использование в инструменте DistanceAccumulation в окне Python.

import arcpy
from arcpy import env
from arcpy.sa import *
env.workspace = "C:/sapyexamples/data"
myVerticalFactor = VfSymLinear(1.0, -90, 90, -0.01111)
outDistAccum = DistanceAccumulation("Source.shp", "", "elev.tif",
                                   "cost.tif", "elev.tif",
                                    myVerticalFactor)
outDistAccum.save("C:/sapyexamples/output/distAccumVfSL.tif")
VfSymLinear, пример 2 (автономный скрипт)

Выполняет анализ DistanceAccumulation с использованием класса VfSymLinear.

# Name: VfSymLinear_Ex_02.py
# Description: Uses the VfSymLinear 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 VfSymLinear Object
zeroFactor = 1.0
lowCutAngle = -90
highCutAngle = 90
slope = -0.01111
myVerticalFactor = VfSymLinear(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/distaccumvfSL2.tif")

Связанные разделы