観測ポイント(Observer Points) (3D Analyst)
使用法
-
観測ポイントの決定は、コンピュータに負荷がかかる処理です。処理にかかる時間は、解像度によって変わります。事前調査の場合、粗いセル サイズにして入力のセル数を減らすことも考えられます。最終結果を生成する準備が整ったら、フル解像度のラスタを使用します。
-
入力ラスタにサンプリング エラーによって発生した望ましくないノイズが含まれていて、ArcGIS Spatial Analyst エクステンションを使用できる場合、このツールを実行する前に [フォーカル統計(Focal Statistics)] ツールの [MEAN] オプションのようなローパス フィルタを使用することでラスタをなめらかにすることも考えられます。
-
各セルの中心の可視または不可視は、セルの中心における高度をローカル水平線に対する高度と比較して決定されます。ローカル水平線は、観測点と各セルの中心との間にある地形を考慮して計算されます。観測点がローカル水平線より上にある場合、可視とみなされます。
ツールでは、オプションで AGL(Above Ground Level)出力ラスタを提供しています。AGL 出力ラスタの各セルには、1 つ以上の観測点からセルを見通すために、セルに追加する必要がある高さの最小値が記録されます。
入力観測フィーチャに複数の観測点が含まれているとき、出力値はすべての観測点における AGL 値の最小値になります。
構文
パラメータ | 説明 | データ タイプ |
in_raster |
入力サーフェス ラスタ。 | Raster Layer |
in_observer_point_features |
観測点の位置を特定するポイント フィーチャクラス。 最大ポイント数は 16 です。 | Feature Layer |
out_raster |
出力ラスタ。 出力では、各ラスタのサーフェス位置から見える観測点を正確に特定します。 | Raster Dataset |
z_factor (オプション) | サーフェス Z 単位あたりの地表 X、Y 単位の数。 Z 単位の測定基準が入力サーフェスの X、Y 単位と異なる場合、Z 係数を使用して Z 測定単位を調整します。最終的な出力サーフェスを計算する際、入力サーフェスの Z 値に Z 係数が乗算されます。 X、Y 単位と Z 単位の測定基準が同じ場合、Z 係数は 1(デフォルト値)になります。 X、Y 単位と Z 単位の測定基準が異なる場合は、Z 係数に適切な値を設定する必要があります。Z 係数が適切でないと、正しい結果が得られません。たとえば、Z 単位がフィートであり、X、Y 単位がメートルの場合、Z 係数 0.3048 を使用して Z 単位をフィートからメートルへ変換します(1 フィート = 0.3048 メートル)。 | Double |
curvature_correction (オプション) |
地球の曲率の補正を適用します。
| Boolean |
refractivity_coefficient (オプション) |
大気中での可視光線の屈折係数。 デフォルト値は 0.13 です。 | Double |
out_agl_raster (オプション) |
出力 AGL(Above Ground Level)ラスタ。 AGL の結果は、各セル値が 1 つ以上の観測点からそのセルを見通すために、セルに追加する必要がある高さの最小値となっているラスタになります。 この出力ラスタでは、すでに見通せるセルには値 0 が設定されます。 | Raster |
コードのサンプル
この例では、各ラスタのサーフェス位置から見える観測点を正確に特定します。
import arcpy
from arcpy import env
env.workspace = "C:/data"
arcpy.ObserverPoints_3d("elevation","observers.shp", "C:/output/outobspnt01",
1, "CURVED_EARTH", 0.13)
この例では、各ラスタのサーフェス位置から見える観測点を正確に特定します。
# Name: ObserverPoints_3d_Ex_02.py
# Description: Identifies exactly which observer points are visible
# from each raster surface location.
# Requirements: 3D Analyst Extension
# Import system modules
import arcpy
from arcpy import env
# Set environment settings
env.workspace = "C:/data"
# Set local variables
inRaster = "elevation"
inObsPoints = "observers.shp"
outRaster = "C:/output/outobspnt02"
zFactor = 1
useEarthCurv = "CURVED_EARTH"
refractionVal = 0.13
# Check out the ArcGIS 3D Analyst extension license
arcpy.CheckOutExtension("3D")
# Execute ObserverPoints
arcpy.ObserverPoints_3d(inRaster, inObsPoints, outRaster, zFactor,
useEarthCurv, refractionVal)