** (Power) operator

需要 Spatial Analyst 许可。

获得 Image Analyst 许可后可用。

摘要

对栅格中的像元值进行乘方运算,将结果作为另一栅格的值。

插图

“幂”图示
OutRas = Raster("InRas1") ** 2

说明

使用具有栅格输入的运算符时,结果将为栅格。 但是,如果所有输入均为数字,那么结果也是数字。

当表达式中使用多个运算符时,运算符不一定按照从左到右的顺序执行。 具有最高优先级值的运算符将首先执行。 有关详细信息,请参阅使用“地图代数”中的运算符中的运算符优先级表。 您可使用括号来控制执行顺序。

无论输入值为何种类型,输出值都始终为浮点型。

执行“幂”运算的另一个方法为 a **= b,其为 a = a ** b 的另一种写法。

如果两个输入均为单波段栅格,或者输入之一是常量,则输出将是单波段栅格。

如果两个输入均为多波段栅格,则该运算符将针对一个输入中的每个波段执行运算,并且输出将为多波段栅格。 每个多波段输入中的波段数必须相同。

如果其中一个输入为多波段栅格,而另一个输入为常量,则该运算符将针对多波段输入中每个波段的常量值执行运算,并且输出将为多波段栅格。

如果两个输入均为具有相同数量变量的多维栅格,则该运算符将对具有相同维度值的所有剖切片执行运算,并且输出将为多维栅格。 输入中的变量必须具有相同维度或常见维度,但不能具有不常见的维度。

如果两个输入均具有一个变量但名称不同,请将 matchMultidimensionalVariable 地理处理环境设置为 False 以执行该运算。

如果其中一个输入为多维栅格,而其他输入为常量,则该运算符将针对常量值对所有变量的所有剖切片执行运算,并且输出将为多维栅格。

参数

操作数说明数据类型
in_raster_or_constant1

要进行由第二个输入定义的乘方运算的输入值。

如果第一个输入为栅格,第二个输入为标量,则以各输入栅格值为底、以标量值为幂做乘方运算,从而创建输出栅格。

Raster Layer | Constant
in_raster_or_constant2

用于确定第一个输入中的值的幂的输入。

如果第一个输入为标量,第二个输入为栅格,则以标量值为底、以各输入栅格值为幂做乘方运算,从而创建输出栅格。

Raster Layer | Constant

代码示例

**(幂)示例 1(Python 窗口)

本示例使用第二个输入栅格中的值作为对第一个输入栅格中的值进行乘方运算的幂。

import arcpy
from arcpy import env
from arcpy.sa import *
env.workspace = "C:/sapyexamples/data"
outPower = Raster("degs") ** Raster("cost")
outPower.save("C:/sapyexamples/output/outpower.img")
**(幂)示例 2(独立脚本)

本示例使用第二个输入栅格中的值作为对第一个输入栅格中的值进行乘方运算的幂。

# Name: Op_Power_Ex_02.py
# Description: Raises the cells in a raster to the power of the values
#              found in another raster
# 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
inRaster1 = Raster("degs")
inRaster2 = Raster("cost")

# Execute Power
outPower = inRaster1 ** inRaster2

# Save the output 
outPower.save("C:/sapyexamples/output/outpower")

相关主题