<< (Bitwise Left Shift) operator

Disponible avec une licence Spatial Analyst.

Disponible avec une licence Image Analyst.

Résumé

Performs a Bitwise Left Shift operation on the binary values of two input rasters.

Illustration

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

Discussion

Lorsque vous utilisez un opérateur avec un raster en entrée, le résultat est un raster. En revanche, si toutes les entrées sont des nombres, le résultat est un nombre.

Si plusieurs opérateurs sont utilisés dans une expression, ils ne sont pas nécessairement exécutés de gauche à droite. L'opérateur doté de la valeur de priorité la plus élevée est exécuté en premier. Pour plus d'informations sur la priorité des opérateurs, consultez la rubrique Table de priorité des opérateurs. Vous pouvez utiliser des parenthèses pour contrôler l'ordre d'exécution.

The bitwise operators work on 32-bit integers.

If floating-point values are input, they are converted to integer values through truncation before the bitwise operation is performed. The output values are always integer.

Two inputs (rasters or numbers) are necessary for the bitwise operation to take place.

The order of input is relevant in the Bitwise Left Shift operation.

Binary values are stored in two's complement.

The leftmost bit position is reserved for the sign of the value (positive or negative). If the integer is positive, the bit position is zero; if it's negative, the bit position is one.

The Bitwise Left Shift operation does no wrapping of bits. The leftmost bit is dropped.

Another way to perform the Bitwise Left Shift operation is a <<= b, which is an alternative way to write a = a << b.

Si les deux entrées correspondent à des rasters monocanaux ou que l’une des entrées est une constante, la sortie correspond à un raster monocanal.

Si les deux entrées correspondent à des rasters multicanaux ou que l’une des entrées est une constante, la sortie correspond à un raster multicanal. Le nombre de canaux de chaque entrée multicanal doit être identique.

L’opérateur effectue l’opération sur chaque canal d’une entrée par rapport au canal correspondant de l’autre entrée. Si l’une des entrées correspond à un raster multicanal et que l’autre entrée est une constante, l’opérateur effectue l’opération par rapport à la valeur constante de chaque canal de l’entrée multicanal.

Syntaxe

in_raster_or_constant1 << in_raster_or_constant2
OpérandeExplicationType de données
in_raster_or_constant1

Raster en entrée sur lequel exécuter le décalage.

L'entrée peut être un nombre entier ou à virgule flottante, mais les valeurs à virgule flottante sont converties en nombres entiers avant l'exécution de l'opération bit à bit.

If the first input is a raster and the second is a scalar, an output raster is created with each input raster value being bitwise left shifted by the scalar value.

Raster Layer | Constant
in_raster_or_constant2

The input raster defining the number of positions to shift the bits.

L'entrée peut être un nombre entier ou à virgule flottante, mais les valeurs à virgule flottante sont converties en nombres entiers avant l'exécution de l'opération bit à bit.

If the first input is a scalar and the second is a raster, an output raster is created with each input raster value defining the bitwise left shift for the scalar value.

Raster Layer | Constant

Valeur renvoyée

NomExplicationType de données
out_raster

Objet raster en sortie.

The cell values are the result of a Bitwise Left Shift operation on the inputs.

Raster

Exemple de code

<< (Bitwise Left Shift) example 1 (Python window)

This sample performs a Bitwise Left Shift operation on two input rasters.

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")
<< (Bitwise Left Shift) example 2 (stand-alone script)

This sample performs a Bitwise Left Shift operation on two input rasters.

# 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")

Rubriques connexes