VfInverseLinear

需要 Spatial Analyst 许可。

摘要

通过逆线性函数定义垂直成本系数和垂直相对移动角度之间的关系。

插图

VfinverseLinear 垂直系数图像
路径距离功能的 VfInverseLinear 垂直系数。

说明

VfInverseLinear 对象用于 Spatial Analyst 工具路径距离路径距离分配路径距离回溯链接

垂直系数 (VF) 对象用于定义垂直成本系数和垂直相对移动角度 (VRMA) 之间的关系。

VF 用于定义从一个像元移至下一像元的垂直阻力。

VRMA 用于确定“起始”像元或处理像元与“终止”像元之间的坡度角。

VF 由 VRMA-VF 坐标系中的一条直线的逆向值确定。这条线在 y 轴(表示 VF 系数)上与零系数相关联的值处进行截取。如果使用斜率参数指定,则可以确定线的斜率。

语法

 VfInverseLinear ({zeroFactor}, {lowCutAngle}, {highCutAngle}, {slope})
参数说明数据类型
zeroFactor

zeroFactor 将用于确定逆线性函数的 y 截距。

(默认值为 1.0)

Double
lowCutAngle

用于定义阈值下限的 VRMA 度数,如果低于(小于)该值,则将 VF 设置为无穷大。

(默认值为 -45.0)

Double
highCutAngle

用于定义阈值上限的 VRMA 度数,如果高于(大于)该值,则将 VF 设置为无穷大。

(默认值为 45.0)

Double
slope

在 VRMA-VF 坐标系中,确定直线的斜率。斜率被指定为垂直增量/水平增量。例如,30 度斜率是 1/30,指定为 0.03333(竖直增量/水平增量:y 轴 1 VF/x 轴 30 度);-45 度斜率为 -0.02222。

(默认值为 -0.022222)

Double

属性

属性说明数据类型
zeroFactor
(可读写)

zeroFactor 将用于确定垂直系数类的 y 截距。

Double
lowCutAngle
(可读写)

用于定义阈值下限的 VRMA 度数,如果低于(小于)该值,则将 VF 设置为无穷大。

Double
highCutAngle
(可读写)

用于定义阈值上限的 VRMA 度数,如果高于(大于)该值,则将 VF 设置为无穷大。

Double
slope
(可读写)

在 VRMA-VF 坐标系中,确定直线的斜率。斜率被指定为垂直增量与水平增量的比值。例如,30 度斜率是 1/30,指定为 0.03333(竖直增量/水平增量:y 轴 1 VF/x 轴 30 度);90 度斜率为 0.011111。

Double

代码示例

VfInverseLinear 示例 1(Python 窗口)

演示如何创建 VfInverseLinear 类以及如何在 Python 窗口的 PathDistance 工具中使用该类。

import arcpy
from arcpy import env
from arcpy.sa import *
env.workspace = "C:/sapyexamples/data"
myVerticalFactor = VfInverseLinear(1.0, -45, 45, -0.02222)
outPathDist = PathDistance("source.shp", "costraster", "", "", "", "",
                           myVerticalFactor)
outPathDist.save("C:/sapyexamples/output/pathdistvfil")
VfInverseLinear 示例 2(独立脚本)

使用 VfInverseLinear 类执行 PathDistance 分析。

# Name: VfInverseLinear_Ex_02.py
# Description: Uses the VfInverseLinear 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 VfInverseLinear Object
zeroFactor = 1.0
lowCutAngle = -45
highCutAngle = 45
slope = -0.02222
myVerticalFactor = VfInverseLinear(zeroFactor, lowCutAngle, highCutAngle,
                                    slope)

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

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

相关主题