<< (按位左移)

摘要

对两个输入栅格的二进制值执行按位左移运算。

插图

Bitwise Left Shift illustration
OutRas = Raster("InRas1") << 1

讨论

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

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

按位运算符对 32 位整数有效。

如果输入值为浮点型,则值会在执行按位操作前通过截断转换为整型值。输出值始终是整数。

要进行此按位操作,需要两个输入值(栅格或数值)。

在“按位左移”运算中,运算结果与输入值的顺序有关。

二进制值以二的补码形式存储。

最左边的位预留给值的符号(正号或负号)。如果整数为正,则该位为 0;如果为负,则该位为 1。

“按位左移”运算不会将移出的高位补到低位。移出的高位将被删去。

执行“按位左移”运算的另一个方法为 a <<= b,其为 a = a << b 的另一种写法。

语法

in_raster_or_constant1 << in_raster_or_constant2
操作数说明数据类型
in_raster_or_constant1

要执行移位操作的输入栅格。

输入可以是整型或浮点型,但执行按位运算前浮点值将转换为整型。

如果第一个输入为栅格,第二个输入为标量,则将各输入栅格值按位左移标量值,从而创建输出栅格。

Raster Layer | Constant
in_raster_or_constant2

定义移动位数的输入栅格。

输入可以是整型或浮点型,但执行按位运算前浮点值将转换为整型。

如果第一个输入为标量,第二个输入为栅格,则由各输入栅格值对标量值的按位左移进行定义,从而创建输出栅格。

Raster Layer | Constant

返回值

名称说明数据类型
out_raster

输出栅格对象。

像元值是对输入进行“按位左移”运算的结果。

Raster

代码示例

<<(按位左移)示例 1(Python 窗口)

本示例对两个输入栅格执行“按位左移”运算。

import arcpy
from arcpy import env
from arcpy.sa import *
env.workspace = "C:/sapyexamples/data"
outBitwiseLS = Raster("degs") << Raster("negs")
outBitwiseLS.save("C:/sapyexamples/output/outbitls.tif")
<<(按位左移)示例 2(独立脚本)

本示例对两个输入栅格执行“按位左移”运算。

# Name: Op_BitwiseLeftShift_Ex_02.py
# Description: Performs a Bitwise Left Shift operation on the binary
#     values of two input rasters
# 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("negs")

# Check out the ArcGIS Spatial Analyst extension license
arcpy.CheckOutExtension("Spatial")

# Execute BitwiseLeftShift
outBitwiseLShift = inRaster1 << inRaster2

# Save the output 
outBitwiseLShift.save("C:/sapyexamples/output/outlshift")

环境

相关主题


7/10/2012