操作数 | 说明 | 数据类型 |
in_raster_or_constant1 | 要执行移位操作的输入栅格。 输入可以是整型或浮点型,但执行按位运算前浮点值将转换为整型。 如果第一个输入为栅格,第二个输入为标量,则将各输入栅格值按位左移标量值,从而创建输出栅格。 | Raster Layer | Constant |
in_raster_or_constant2 | 定义移动位数的输入栅格。 输入可以是整型或浮点型,但执行按位运算前浮点值将转换为整型。 如果第一个输入为标量,第二个输入为栅格,则由各输入栅格值对标量值的按位左移进行定义,从而创建输出栅格。 | Raster Layer | Constant |
需要 Spatial Analyst 许可。
获得 Image Analyst 许可后可用。
摘要
对两个输入栅格的二进制值执行“按位左移”运算。
插图
说明
使用具有栅格输入的运算符时,结果将为栅格。 但是,如果所有输入为数字,则结果也是数字。
当表达式中使用多个运算符时,其不一定按照从左到右的顺序执行。 具有最高优先值的运算符将首先执行。 有关详细信息,请参阅在 Map Algebra 中使用运算符中的运算符优先级表。 您可使用括号来控制执行顺序。
按位运算符对 32 位整数有效。
如果浮点值为输入,则在执行按位操作之前,会通过截断将其转换为整型值。 输出值始终是整数。
要进行此按位操作,需要两个输入值(栅格或数值)。
在“按位左移”运算中,运算结果与输入值的顺序有关。
二进制值以二的补码形式存储。
最左边的位预留给值的符号(正号或负号)。 如果整数为正,则该位为 0;如果为负,则该位为 1。
“按位左移”运算不会将移出的高位补到低位。 移出的高位将被删去。
执行“按位左移”运算的另一个方法为 a <<= b,其为 a = a << b 的另一种写法。
如果两个输入都是单波段栅格,或者输入之一是常量,则输出将是单波段栅格。
如果两个输入都是多波段栅格,则运算符将从一个输入对每个波段执行运算,而输出将为多波段栅格。 每个多波段输入中的波段数必须相同。
如果输入之一是多波段栅格,而另一个输入是常量,则该运算符将针对多波段输入中每个波段的常量值执行预算,而输出将为多波段栅格。
如果两个输入都是具有相同数量变量的多维栅格,则运算符将对具有相同维度值的所有切片执行运算,而输出将为多维栅格。 输入中的变量必须具有相同维度或常用维度,但不能包含不常用维度。
如果两个输入均具有一个变量但名称不同,请将 matchMultidimensionalVariable 地理处理环境设置为 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")