Bitwise XOr (Spatial Analyst)

Spatial Analyst のライセンスで利用可能。

Image Analyst ライセンスで利用できます。

サマリー

2 つの入力ラスターのバイナリ値に対してビット単位の排他的論理和演算を行います。

ビット演算ツールの詳細

Bitwise XOr の図
OutRas = BitwiseXOr(InRas1, InRas2)

使用法

  • このビット単位の演算を実行するには、2 つの入力値が必要です。

  • このツールでは、入力の順序は関係ありません。

  • 入力値が浮動小数点数値の場合は、ビット単位の演算を実行する前に値を切り捨てて整数値に変換されます。

  • ビット単位の演算では、以下の点に注意してください。

    • バイナリ値は 2 の補数として格納されます。
    • ツールは 32 ビット整数を対象とします。
    • 最左端のビット位置は値の符号 (正または負) のために予約されています。 整数が正の値である場合、そのビット位置の値は 0 で、負の値である場合、そのビット位置の値は 1 です。

  • Bitwise XOr 演算では、符号ビットを他のビットと同様に処理します。 セル位置への一方または両方の入力値が負の場合は、出力値が負になり、両方の入力値が正の場合は、出力値が正になります。

  • 両方の入力がシングルバンド ラスターである場合、またはいずれかの入力が定数である場合、出力はシングルバンド ラスターになります。

  • 両方の入力がマルチバンド ラスターである場合、ツールは 1 つの入力の各バンドに対して演算を実行し、出力はマルチバンド ラスターになります。 各マルチバンド入力のバンド数は同一である必要があります。

  • 一方の入力がマルチバンド ラスターで、他方の入力が定数である場合、ツールは、マルチバンド入力内の各バンドの定数値を使用して演算を実行し、出力はマルチバンド ラスターになります。

  • 両方の入力が、同数の変数を含む多次元ラスター データの場合、このツールは、ディメンション値が同じすべてのスライスについて演算を実行します。 出力は CRF 形式の多次元ラスターになります。 このツールで処理を行うには、一般的なディメンションと一般的なディメンション値が入力の変数に少なくとも 1 つ必要です。これらがないとエラーが発生します。

    両方の入力に 1 つの変数が含まれているものの、名前が異なる場合は、処理を行う前に多次元変数の照合ジオプロセシング環境をオフにします (Python では arcpy.env.matchMultidimensionalVariable = False を設定)。

    一方の入力が多次元ラスターで、他方の入力が定数である場合、ツールは、すべての変数のすべてのスライスについて、その定数値を使用して演算を実行し、出力は多次元ラスターになります。

  • このツールに適用されるジオプロセシング環境の詳細については、「解析環境と Spatial Analyst」をご参照ください。

パラメーター

ラベル説明データ タイプ
入力ラスター、または定数値 1

このビット単位演算で使用する最初の入力。

他のパラメーターでラスターが指定されている場合、数値をこのパラメーターの入力として使用できます。 両方の入力で数値を指定するには、セル サイズと範囲を最初に環境で設定しておく必要があります。

Raster Layer; Constant
入力ラスター、または定数値 2

このビット単位演算で使用する 2 番目の入力。

他のパラメーターでラスターが指定されている場合、数値をこのパラメーターの入力として使用できます。 両方の入力で数値を指定するには、セル サイズと範囲を最初に環境で設定しておく必要があります。

Raster Layer; Constant

戻り値

ラベル説明データ タイプ
出力ラスター

出力ラスター。

セル値は、2 つの入力に対する Bitwise eXclusive Or 演算の結果です。

Raster

BitwiseXOr(in_raster_or_constant1, in_raster_or_constant2)
名前説明データ タイプ
in_raster_or_constant1

このビット単位演算で使用する最初の入力。

他のパラメーターでラスターが指定されている場合、数値をこのパラメーターの入力として使用できます。 両方の入力で数値を指定するには、セル サイズと範囲を最初に環境で設定しておく必要があります。

Raster Layer; Constant
in_raster_or_constant2

このビット単位演算で使用する 2 番目の入力。

他のパラメーターでラスターが指定されている場合、数値をこのパラメーターの入力として使用できます。 両方の入力で数値を指定するには、セル サイズと範囲を最初に環境で設定しておく必要があります。

Raster Layer; Constant

戻り値

名前説明データ タイプ
out_raster

出力ラスター。

セル値は、2 つの入力に対する Bitwise eXclusive Or 演算の結果です。

Raster

コードのサンプル

BitwiseXOr の例 1 (Python ウィンドウ)

この例では、2 つの 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 (スタンドアロン スクリプト)

この例では、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"

# Execute BitwiseXOr
outBitwiseXOr = BitwiseXOr(inRaster1, inRaster2)

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

ライセンス情報

  • Basic: 次のものが必要 Spatial Analyst または Image Analyst
  • Standard: 次のものが必要 Spatial Analyst または Image Analyst
  • Advanced: 次のものが必要 Spatial Analyst または Image Analyst

関連トピック