操作数 | 说明 | 数据类型 |
in_raster_or_constant1 | 要执行移位运算的输入栅格。 输入可以是整型或浮点型,但执行按位运算前浮点值将转换为整型。 如果第一个输入为栅格,第二个输入为标量,则将各输入栅格值按位左移标量值,从而创建输出栅格。 | Raster Layer | Constant |
in_raster_or_constant2 | 定义移动位数的输入栅格。 输入可以是整型或浮点型,但执行按位运算前浮点值将转换为整型。 如果第一个输入为标量,第二个输入为栅格,则由各输入栅格值对标量值的按位左移进行定义,从而创建输出栅格。 | Raster Layer | Constant |
需要 Spatial Analyst 许可。
获得 Image Analyst 许可后可用。
摘要
对两个输入栅格的二进制值执行“按位左移”运算。
插图
说明
使用具有栅格输入的运算符时,结果将为栅格。 但是,如果所有输入均为数字,那么结果也是数字。
当表达式中存在多个运算符时,运算符不一定按照从左到右的顺序运行。 具有最高优先级值的运算符将首先运行。 有关详细信息,请参阅使用“地图代数”中的运算符中的运算符优先级表。 可使用括号来控制运行顺序。
按位运算符对 32 位整数有效。
如果浮点值为输入,则在执行按位操作之前,会通过截断将其转换为整型值。 输出值始终是整数。
要进行此按位操作,需要两个输入值(栅格或数值)。
在“按位左移”运算中,运算结果与输入值的顺序有关。
二进制值以二的补码形式存储。
最左边的位预留给值的符号(正号或负号)。 如果整数为正,则该位为 0;如果为负,则该位为 1。
“按位左移”运算不会将移出的高位补到低位。 移出的高位将被删去。
执行“按位左移”运算的另一个方法为 a <<= b,其为 a = a << b 的另一种写法。
如果两个输入均为单波段栅格,或者输入之一是常量,则输出将是单波段栅格。
如果两个输入均为多波段栅格,则该运算符将针对一个输入中的每个波段执行运算,并且输出将为多波段栅格。 每个多波段输入中的波段数必须相同。
如果其中一个输入为多波段栅格,而另一个输入为常量,则该运算符将针对多波段输入中每个波段的常量值执行运算,并且输出将为多波段栅格。
如果两个输入均为具有相同数量变量的多维栅格,则该运算符将对具有相同维度值的所有剖切片执行运算,并且输出将为多维栅格。 输入中的变量必须具有相同维度或常见维度,但不能具有不常见的维度。
如果两个输入均具有一个变量但名称不同,请将匹配多维变量环境设置为 False 以执行该运算。
如果其中一个输入为多维栅格,而其他输入为常量,则该运算符将针对常量值对所有变量的所有剖切片执行运算,并且输出将为多维栅格。
参数
代码示例
本示例对两个输入栅格执行“按位左移”运算。
import arcpy
from arcpy import env
from arcpy.ia import *
env.workspace = "C:/iapyexamples/data"
outBitwiseLS = Raster("degs") << Raster("negs")
outBitwiseLS.save("C:/iapyexamples/output/outbitls.tif")
本示例对两个输入栅格执行“按位左移”运算。
# Name: Op_BitwiseLeftShift_Ex_02.py
# Description: Performs a Bitwise Left Shift operation on the binary
# values of two input rasters
# Requirements: Image Analyst Extension
# Import system modules
import arcpy
from arcpy import env
from arcpy.ia import *
# Set environment settings
env.workspace = "C:/iapyexamples/data"
# Set local variables
inRaster1 = Raster("degs")
inRaster2 = Raster("negs")
# Execute BitwiseLeftShift
outBitwiseLShift = inRaster1 << inRaster2
# Save the output
outBitwiseLShift.save("C:/iapyexamples/output/outlshift")