按位异或 (Image Analyst)

需要 Spatial Analyst 许可。

获得 Image Analyst 许可后可用。

摘要

对两个输入栅格的二进制值执行“按位异或”运算。

了解有关“按位数学”工具工作原理的详细信息

插图

“按位异或”图示
OutRas = BitwiseXOr(InRas1, InRas2)

使用情况

  • 要进行此按位运算,需要两个输入值。

  • 使用此工具时输入的顺序不重要。

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

  • 在位运算中,以下表述为正确的:

    • 二进制值以二的补码形式存储。
    • 工具对 32 位整数有效。
    • 最左边的位预留给值的符号(正号或负号)。 如果为正整型,则该位为 0;如果为负整型,则该位为 1。

  • 按位异或运算将符号位视同任意其他位。 如果某一像元位置的一个或两个输入为负,则输出为负;如果两个输入都为正,则输出为正。

  • 如果两个输入均为单波段栅格,或者输入之一是常量,则输出将是单波段栅格。

  • 如果两个输入均为多波段栅格,则该工具将针对一个输入中的每个波段执行操作,并且输出将为多波段栅格。 每个多波段输入中的波段数必须相同。

  • 如果其中一个输入为多波段栅格,而另一个输入为常量,则该工具将使用多波段输入中每个波段的常量值执行运算,并且输出将为多波段栅格。

  • 如果两个输入均为具有相同数量变量的多维栅格数据,则该工具将对具有相同维度值的所有剖切片执行运算。 输出将是 CRF 格式的多维栅格。 输入中的变量必须至少具有一个常见维度和一个常见维度值以供此工具进行处理,否则将发生错误。

    如果所有输入均具有一个变量但名称不同,请在运行工具之前取消选中匹配多维变量地理处理环境(在 Python 中设置 arcpy.env.matchMultidimensionalVariable = False)。

    如果其中一个输入为多维栅格,而其他输入为常量,则该工具将使用常量值,对所有变量的所有剖切片执行操作,并且输出将为多维栅格。

参数

标注说明数据类型
输入栅格或常量值 1

此“按位与”运算中所使用的第一个输入。

假如已为其他参数指定栅格,则可将数字用作此参数的输入。 要为两个输入指定一个数字,必须先设置像元大小和范围。

Raster Layer; Constant
输入栅格数据或常量值 2

此“按位与”运算中所使用的第二个输入。

假如已为其他参数指定栅格,则可将数字用作此参数的输入。 要为两个输入指定一个数字,必须先设置像元大小和范围。

Raster Layer; Constant

返回值

标注说明数据类型
输出栅格

输出栅格。

像元值是对两个输入进行“按位异或”运算的结果。

Raster

BitwiseXOr(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

代码示例

按位异或 (BitwiseXOr) 示例 1(Python 窗口)

本例对两个 Grid 栅格执行“按位异或”运算。

import arcpy
from arcpy import env
from arcpy.ia import *
env.workspace = "C:/iapyexamples/data"
outBitwiseXOr = BitwiseXOr("degs", "negs")
outBitwiseXOr.save("C:/iapyexamples/output/outbitxor")
按位异或 (BitwiseXOr) 示例 2(独立脚本)

此示例对两个 Grid 栅格数据执行“按位异或”运算,并以 IMG 栅格数据的形式输出结果。

# Name: BitwiseXOr_Ex_02.py
# Description: Performs a Bitwise XOr 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 = "degs"
inRaster2 = "negs"

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

# Execute BitwiseXOr
outBitwiseXOr = BitwiseXOr(inRaster1, inRaster2)

# Save the output 
outBitwiseXOr.save("C:/iapyexamples/output/outbitwisexor.img")

许可信息

  • Basic: 需要 Image Analyst 或 Spatial Analyst
  • Standard: 需要 Image Analyst 或 Spatial Analyst
  • Advanced: 需要 Image Analyst 或 Spatial Analyst

相关主题