按位非 (Spatial Analyst)

需要 Spatial Analyst 许可。

获得 Image Analyst 许可后可用。

摘要

对输入栅格的二进制值执行“按位非”(求反)运算。

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

插图

“按位非”图示
OutRas = BitwiseNot(InRas1)

使用情况

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

  • 在按位运算中,以下表述均为真:

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

  • “按位非”运算将符号位视同任意其他位。 如果某一像元位置处的输入为负,则输出为负;如果输入为正,则输出为正。

  • 如果输入是多波段栅格,则输出也将为多波段栅格。 该工具将在输入中的每个波段上执行操作。

  • 在 ArcPy 中,如果输入是多维栅格,则将处理所有变量的所有切片,而输出将为多维栅格。

  • 有关适用于此工具的地理处理环境的详细信息,请参阅分析环境和 Spatial Analyst

参数

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

用于执行“按位非”(求反)运算的输入栅格。

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

Raster Layer; Constant

返回值

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

输出栅格。

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

Raster

BitwiseNot(in_raster_or_constant)
名称说明数据类型
in_raster_or_constant

用于执行“按位非”(求反)运算的输入栅格。

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

Raster Layer; Constant

返回值

名称说明数据类型
out_raster

输出栅格。

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

Raster

代码示例

按位非 (BitwiseNot) 示例 1(Python 窗口)

本例对输入的 Grid 栅格执行“按位非”运算。

import arcpy
from arcpy import env
from arcpy.sa import *
env.workspace = "C:/sapyexamples/data"
outBitwiseNot = BitwiseNot("degs")
outBitwiseNot.save("C:/sapyexamples/output/outbitn")
按位非 (BitwiseNot) 示例 2(独立脚本)

本例对输入的 Grid 栅格执行“按位非”运算。

# Name: BitwiseNot_Ex_02.py
# Description: Performs a Bitwise Complement operation on the
#              binary value of an input raster
# 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
inRaster = "degs"

# Execute BitwiseNot
outBitwiseNot = BitwiseNot(inRaster)

# Save the output 
outBitwiseNot.save("C:/sapyexamples/output/outbitnot")

许可信息

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

相关主题