按位异或 (空间分析)
插图
用法
要进行此按位操作,需要两个输入值。
-
使用此工具时输入的顺序不重要。
如果输入为浮点型,则值会在执行按位操作前通过截断转换为整型值。
在按位操作中:
- 二进制值以二的补码的形式存储。
- 工具对 32 位整型起作用。
- 最左边的位会为作为值的符号(正号或负号)而保留。如果为正整型,则该位为 0;如果为负整型,则该位为 1。
-
“按位异或”运算将符号位视同任意其他位。如果某一像元位置的一个或两个输入为负,则输出为负;如果两个输入都为正,则输出为正。
语法
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.sa import * env.workspace = "C:/sapyexamples/data" outBitwiseXOr = BitwiseXOr("degs", "negs") outBitwiseXOr.save("C:/sapyexamples/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: 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 = "degs" inRaster2 = "negs" # Check out the ArcGIS Spatial Analyst extension license arcpy.CheckOutExtension("Spatial") # Execute BitwiseXOr outBitwiseXOr = BitwiseXOr(inRaster1, inRaster2) # Save the output outBitwiseXOr.save("C:/sapyexamples/output/outbitwisexor.img")
相关主题
许可信息
ArcView: 需要 Spatial Analyst
ArcEditor: 需要 Spatial Analyst
ArcInfo: 需要 Spatial Analyst
7/10/2012