VfLinear

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

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

Задает отношение между вертикальным фактором стоимости и вертикальным относительным углом движения через линейную функцию.

Иллюстрация

Изображение вертикального фактора VfLinear
Вертикальный фактор VfLinear для функций PathDistance.

Обсуждение

Объект VfLinear используется в следующих инструментах Spatial Analyst: Путевое расстояние (Path Distance), Распределение по путевому расстоянию (Path Distance Allocation) и Путевое направление (Path Distance Back Link).

Объект вертикального фактора (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. Пример 1 (окно Python)

Демонстрирует создание класса VfLinear и его использование с инструментом PathDistance в окне 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)
outPathDist =  PathDistance("source.shp", "costraster", "", "", "", "",
                            myVerticalFactor)
outPathDist.save("C:/sapyexamples/output/pastdistvfl")
VfLinear. Пример 2 (автономный скрипт)

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

# Name: VfLinear_Ex_02.py
# Description: Uses the VfLinear object to execute the PathDistance 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"

# Create the VfLinear Object
zeroFactor = 1.0
lowCutAngle = -90
highCutAngle = 90
slope = 0.01111
myVerticalFactor = VfLinear(zeroFactor, lowCutAngle, highCutAngle, slope)

# Execute PathDistance
outPathDist =  PathDistance(inSourceData, inCostRaster, "", "", "", "",
                            myVerticalFactor)

# Save the output 
outPathDist.save("C:/sapyexamples/output/pastdistvfl2")

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