<< (Bitwise Left Shift) operator

Disponible avec une licence Spatial Analyst.

Disponible avec une licence Image Analyst.

Synthèse

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, reportez-vous au tableau de priorité des opérateurs dans la rubrique Utiliser des opérateurs en algèbre spatiale. 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 sont des rasters multicanaux, l’opérateur effectue l’opération sur chaque canal d’une entrée et la sortie est un raster multicanal. Le nombre de canaux de chaque entrée multicanale est identique.

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 et la sortie est un raster mutlicanal.

Si les deux entrées sont des rasters multidimensionnels comportant le même nombre de variables, l’opérateur effectue l’opération pour toutes les tranches dotées de la même valeur de dimension et la sortie est un raster multidimensionnel. Les variables des entrées doivent avoir les mêmes dimensions ou une dimension commune.

Si les deux entrées possèdent une variable mais ont des noms différents, définissez l’environnement de géotraitement matchMultidimensionalVariable sur False pour effectuer l’opération.

Si l’une des entrées correspond à un raster multidimensionnel et que l’autre entrée est une constante, l’opérateur effectue l’opération pour toutes les tranches de toutes les variables par rapport à la valeur constante et la sortie est un raster multidimensionnel.

Paramètres

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

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.sa import *
env.workspace = "C:/sapyexamples/data"
outBitwiseLS = Raster("degs") << Raster("negs")
outBitwiseLS.save("C:/sapyexamples/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: 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")

# Execute BitwiseLeftShift
outBitwiseLShift = inRaster1 << inRaster2

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

Rubriques connexes