VfSecCos

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

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

Определяет отношение между фактором вертикальной стоимости и углом отклонения от вертикали (VRMA) посредством функции секанты-косинуса. Если VRMA отрицательный, вертикальный коэффициент определяется секущей функцией, а если неотрицательный - косинусной функцией.

Иллюстрация

Диаграмма вертикального фактора VfSecCos
Диаграмма вертикального фактора секанты-косинуса.

Обсуждение

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

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

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

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

Когда значение угла VRMA (в градусах) выражено отрицательным значением, VF определяется косинусом VRMA. Если значение угла VRMA (в градусах) выражено положительным значением, VF определяется секансом VRMA.

Синтаксис

VfSecCos ({lowCutAngle}, {highCutAngle}, {secPower}, {cosPower})
ПараметрОписаниеТип данных
lowCutAngle

Значение VRMA в градусах, определяющее нижний порог, ниже которого значения VF устанавливаются равными бесконечности.

(Значение по умолчанию — -90.0)

Double
highCutAngle

Значение VRMA в градусах, определяющее верхний порог, выше которого значения VF устанавливаются равными бесконечности.

(Значение по умолчанию — 90.0)

Double
secPower

Степень, в которую будут возведены значения функции секанса для углов VRMA. VF определяется следующим образом:

 VF = sec(VRMA)power

(Значение по умолчанию — 1.0)

Double
cosPower

Степень, в которую будут возведены значения функции косинуса для углов VRMA. VF определяется следующим образом:

 VF = cos(VRMA)power

(Значение по умолчанию — 1.0)

Double

Свойства

СвойствоОписаниеТип данных
lowCutAngle
(чтение и запись)

Значение VRMA в градусах, определяющее нижний порог, ниже которого значения VF устанавливаются равными бесконечности.

Double
highCutAngle
(чтение и запись)

Значение VRMA в градусах, определяющее верхний порог, выше которого значения VF устанавливаются равными бесконечности.

Double
secPower
(чтение и запись)

Степень, в которую будут возведены значения функции секанса для углов VRMA. VF определяется следующим образом:

 VF = sec(VRMA)power

Double
cosPower
(чтение и запись)

Степень, в которую будут возведены значения функции косинуса для углов VRMA. VF определяется следующим образом:

 VF = cos(VRMA)power

Double

Пример кода

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

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

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

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

# Name: VfSecCos_Ex_02.py
# Description: Uses the VfSecCos 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 VfSecCos Object
lowCutAngle = -90
highCutAngle = 90
secPower = 1
cosPower = 1
myVerticalFactor = VfSecCos(lowCutAngle, highCutAngle, secPower, cosPower)

# 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/distaccumvfSC2.tif")

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