Visibilité (ArcGIS Spatial Analyst)
Récapitulatif
Détermine les emplacements de surfaces raster visibles pour un ensemble d'entités d'observation ou identifie les points d'observation visibles depuis chaque emplacement de la surface raster.
Utilisation
-
Cet outil prend en charge deux types d'analyse de visibilité (FREQUENCY et OBSERVERS), qui sont contrôlés par le paramètre de l'outil Type d'analyse. Pour le type d'analyse FREQUENCY, l'outil détermine quels emplacements de surfaces raster sont visibles pour un ensemble de points d'observation. Pour OBSERVERS, il identifie les points d'observation visibles depuis chaque emplacement de la surface raster.
Si le raster en entrée comporte du bruit indésirable causé par des erreurs d'échantillonnage, vous pouvez lisser le raster avec un filtre passe-bas, comme l'option Moyenne de Statistiques focales, avant d'exécuter cet outil.
La visibilité de chaque centre de cellule est déterminée par la comparaison de l'angle d'altitude vis-à-vis du centre de cellule avec l'angle d'altitude vis-à-vis de l'horizon local. L'horizon local est calculé en fonction du MNT intermédiaire entre le point d'observation et le centre de cellule actuel. Si le point se trouve au-dessus de l'horizon local, il est considéré comme visible.
Un raster en sortie facultatif AGL (Above-Ground-Level, au-dessus du niveau du sol) est fourni par l'outil. Chaque cellule du raster en sortie AGL enregistre la hauteur minimale devant être ajoutée à cette cellule pour la rendre visible par au moins un observateur.
Lorsque les entités d'observation en entrée contiennent plusieurs observateurs, la valeur en sortie est le minimum des valeurs AGL provenant de chaque observateur.
Utilisez les paramètres du point d’observation pour mieux contrôler le processus d'analyse de visibilité. Par exemple, par l'intermédiaire des paramètres de décalage du point d'observation, vous pouvez spécifier un décalage pour l'altitude du point d'observation dans l'analyse de visibilité.
Si le raster en entrée doit être ré-échantillonné, la technique bilinéaire sera utilisée. Un raster en entrée peut être ré-échantillonné par exemple lorsque le système de coordonnées en sortie, l'étendue ou la taille de cellule est différent(e) de celui ou celle en entrée.
Syntaxe
Paramètre | Explication | Type de données |
in_raster |
Raster de surface en entrée. | Raster Layer |
in_observer_features |
Classe d'entités qui identifie les emplacements des points d'observation. Il peut s'agir d'entités points ou polylignes en entrée. | Feature Layer |
out_agl_raster (Facultatif) |
Raster AGL en sortie. Le raster AGL obtenu est un raster dans lequel la valeur de chaque cellule correspond à la hauteur minimale devant être ajoutée à une cellule (qui, sinon, ne serait pas visible) pour la rendre visible par au moins un observateur. Les cellules qui étaient déjà visibles auront la valeur 0 dans ce raster en sortie. | Raster |
analysis_type (Facultatif) |
Type d'analyse de visibilité.
| String |
nonvisible_cell_value (Facultatif) | Valeur attribuée aux cellules non visibles.
| Boolean |
z_factor (Facultatif) |
Nombre d'unités x, y au sol dans une unité z de surface. Le facteur z ajuste les unités de mesure des unités z lorsqu'elles sont différentes des unités x,y de la surface en entrée. Les valeurs z de la surface en entrée sont multipliées par le facteur z lors du calcul de la surface finale en sortie. Si les unités x,y et les unités z utilisent les mêmes unités de mesure, le facteur z est égal à 1. Si les valeurs x,y et les valeurs z sont exprimées dans des unités de mesure différentes, le facteur z doit être défini comme approprié, sinon les résultats sont incorrects. Par exemple, si les unités z sont des pieds et les unités x,y sont des mètres, vous devez utiliser un facteur z égal à 0,3048 pour convertir les unités z de pieds en mètres (1 pied = 0,3048 mètre). | Double |
curvature_correction (Facultatif) |
Permet de corriger en intégrant la courbure de la Terre.
| Boolean |
refractivity_coefficient (Facultatif) |
Coefficient de réfraction de la lumière visible dans l'air. La valeur par défaut est 0,13. | Double |
surface_offset (Facultatif) |
Cette valeur indique la distance verticale (en unités de surface) à ajouter à la valeur z de chaque cellule, telle qu'elle est prise en compte pour la visibilité. La valeur doit être un entier positif ou une valeur à virgule flottante. Il peut s'agir d'un champ dans le jeu de données d'entités d'observation en entrée ou d'une valeur numérique. Par défaut, un champ numérique OFFSETB est utilisé s'il est présent dans la table attributaire des entités d'observation en entrée. Vous pouvez le remplacer en spécifiant un autre champ numérique ou une constante. Si ce paramètre n'est pas précisé et que le champ par défaut n'est pas présent dans la table attributaire des entités d'observation en entrée, sa valeur par défaut est de 0. | Field | Constant |
observer_elevation (Facultatif) |
Cette valeur permet de définir les altitudes des surfaces des points d'observation ou des sommets. Il peut s'agir d'un champ dans le jeu de données d'entités d'observation en entrée ou d'une valeur numérique. Par défaut, un champ numérique SPOT est utilisé s'il est présent dans la table attributaire des entités d'observation en entrée. Vous pouvez le remplacer en spécifiant un autre champ numérique ou une constante. Si ce paramètre n'est pas précisé et que le champ par défaut n'est pas présent dans la table attributaire des entités d'observation en entrée, il est estimé à l'aide d'une interpolation bilinéaire avec les valeurs d'altitude de surface dans les cellules de voisinage de l'emplacement du point d'observation. | Field | Constant |
observer_offset (Facultatif) |
Cette valeur indique la distance verticale (en unités de surface) à ajouter à l'altitude du point d'observation. La valeur doit être un entier positif ou une valeur à virgule flottante. Il peut s'agir d'un champ dans le jeu de données d'entités d'observation en entrée ou d'une valeur numérique. Par défaut, un champ numérique OFFSETA est utilisé s'il est présent dans la table attributaire des entités d'observation en entrée. Vous pouvez le remplacer en spécifiant un autre champ numérique ou une constante. Si ce paramètre n'est pas précisé et que le champ par défaut n'est pas présent dans la table attributaire des entités d'observation en entrée, sa valeur par défaut est de 1. | Field | Constant |
inner_radius (Facultatif) |
Cette valeur définit la distance de départ à partir de laquelle la visibilité est déterminée. Les cellules plus proches que cette distance ne sont pas visibles dans la sortie, mais peuvent toujours empêcher la visibilité des cellules situées entre le rayon intérieur et le rayon extérieur. Il peut s'agir d'une valeur entière positive ou négative ou d'une valeur à virgule flottante. Si la valeur est positive, elle est interprétée comme une distance de ligne de visée tridimensionnelle. Si la valeur est négative, elle est interprétée comme une distance planimétrique bidimensionnelle. Il peut s'agir d'un champ dans le jeu de données d'entités d'observation en entrée ou d'une valeur numérique. Par défaut, un champ numérique RADIUS1 est utilisé s'il est présent dans la table attributaire des entités d'observation en entrée. Vous pouvez le remplacer en spécifiant un autre champ numérique ou une constante. Si ce paramètre n'est pas précisé et que le champ par défaut n'est pas présent dans la table attributaire des entités d'observation en entrée, sa valeur par défaut est de 0. | Field | Constant |
outer_radius (Facultatif) |
Cette valeur définit la distance maximale à partir de laquelle la visibilité est déterminée. Les cellules situées au-delà de cette distance sont exclues de l'analyse. Il peut s'agir d'une valeur entière positive ou négative ou d'une valeur à virgule flottante. Si la valeur est positive, elle est interprétée comme une distance de ligne de visée tridimensionnelle. Si la valeur est négative, elle est interprétée comme une distance planimétrique bidimensionnelle. Il peut s'agir d'un champ dans le jeu de données d'entités d'observation en entrée ou d'une valeur numérique. Par défaut, un champ numérique RADIUS2 est utilisé s'il est présent dans la table attributaire des entités d'observation en entrée. Vous pouvez le remplacer en spécifiant un autre champ numérique ou une constante. Si ce paramètre n'est pas précisé et que le champ par défaut n'est pas présent dans la table attributaire des entités d'observation en entrée, sa valeur par défaut est l'infini. | Field | Constant |
horizontal_start_angle (Facultatif) |
Cette valeur définit l'angle de départ de la plage d'analyse horizontale. La valeur doit être exprimée en degrés de 0 à 360, 0 étant orienté vers le nord. La valeur par défaut est 0. Il peut s'agir d'un champ dans le jeu de données d'entités d'observation en entrée ou d'une valeur numérique. Par défaut, un champ numérique AZIMUTH1 est utilisé s'il est présent dans la table attributaire des entités d'observation en entrée. Vous pouvez le remplacer en spécifiant un autre champ numérique ou une constante. Si ce paramètre n'est pas précisé et que le champ par défaut n'est pas présent dans la table attributaire des entités d'observation en entrée, sa valeur par défaut est de 0. | Field | Constant |
horizontal_end_angle (Facultatif) |
Cette valeur définit l'angle de fin de la plage d'analyse horizontale. La valeur doit être exprimée en degrés de 0 à 360, 0 étant orienté vers le nord. La valeur par défaut est 360. Il peut s'agir d'un champ dans le jeu de données d'entités d'observation en entrée ou d'une valeur numérique. Par défaut, un champ numérique AZIMUTH2 est utilisé s'il est présent dans la table attributaire des entités d'observation en entrée. Vous pouvez le remplacer en spécifiant un autre champ numérique ou une constante. Si ce paramètre n'est pas précisé et que le champ par défaut n'est pas présent dans la table attributaire des entités d'observation en entrée, sa valeur par défaut est de 360. | Field | Constant |
vertical_upper_angle (Facultatif) |
Cette valeur définit la limite de l'angle vertical supérieur de l'analyse au-dessus du plan horizontal. La valeur doit être exprimée en degrés de 0 à 90 et peut être un entier ou une valeur à virgule flottante. Il peut s'agir d'un champ dans le jeu de données d'entités d'observation en entrée ou d'une valeur numérique. Par défaut, un champ numérique VERT1 est utilisé s'il est présent dans la table attributaire des entités d'observation en entrée. Vous pouvez le remplacer en spécifiant un autre champ numérique ou une constante. Si ce paramètre n'est pas précisé et que le champ par défaut n'est pas présent dans la table attributaire des entités d'observation en entrée, sa valeur par défaut est de 90. | Field | Constant |
vertical_lower_angle (Facultatif) |
Cette valeur définit la limite de l'angle vertical inférieur de l'analyse au-dessous du plan horizontal. La valeur doit être exprimée en degrés de -90 à 0 et peut être un entier ou une valeur à virgule flottante. Il peut s'agir d'un champ dans le jeu de données d'entités d'observation en entrée ou d'une valeur numérique. Par défaut, un champ numérique VERT2 est utilisé s'il est présent dans la table attributaire des entités d'observation en entrée. Vous pouvez le remplacer en spécifiant un autre champ numérique ou une constante. Si ce paramètre n'est pas précisé et que le champ par défaut n'est pas présent dans la table attributaire des entités d'observation en entrée, sa valeur par défaut est de -90. | Field | Constant |
Valeur renvoyée
Nom | Explication | Type de données |
out_raster |
Raster en sortie. La sortie enregistre le nombre de fois où chaque emplacement de cellule dans le raster de surface en entrée est visible depuis les emplacements des points d'observation en entrée (option FREQUENCY) ou enregistre les emplacements des points d'observation visibles depuis chaque cellule de la surface raster (option OBSERVERS). | Raster |
Exemple de code
Cet exemple détermine les emplacements de surface visibles depuis un ensemble de points d'observation définis dans un fichier de formes.
import arcpy
from arcpy import env
from arcpy.sa import *
env.workspace = "c:/sapyexamples/data"
outvis = arcpy.sa.Visibility("elevation", "observers.shp", "c:/sapyexamples/output/aglout1",
"FREQUENCY", "NODATA", "1", "CURVED_EARTH", "0.13",
"OFFSETB", "SPOT", "OFFSETA", "RADIUS1", "RADIUS2",
"AZIMUTH1", "AZIMUTH2", "VERT1", "VERT2")
outvis.save("c:/sapyexamples/output/visiout1")
Cet exemple détermine les points d'observation visibles à chaque emplacement de la surface.
# Name: Visibility_Ex_02.py
# Description: Determines the raster surface locations visible to a set of
# observer features.
# 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 = "elevation"
inObserverFeatures = "observers.shp"
aglOutput = "c:/sapyexamples/output/aglout1"
analysisType = "OBSERVERS"
nonVisibleValue = "ZERO"
zFactor = 1
useEarthCurvature = "CURVED_EARTH"
refractivityCoefficient = 0.13
surfaceOffset = 500
observerElevation = 2000
observerOffset = 500
innerRadius = 20000
outerRadius = 100000
horizStartAngle = 45
horizEndAngle = 215
vertUpperAngle = 5
vertLowerAngle = -5
# Check out the ArcGIS Spatial Analyst extension license
arcpy.checkOutExtension("Spatial")
# Execute Visibility
outvis = arcpy.sa.Visibility(inRaster, inObserverFeatures, algOutput, analysisType,
nonVisibleValue, zFactor, useEarthCurvature,
refractivityCoefficient, surfaceOffset, observerElevation,
observerOffset, innerRadius, outerRadius, horizStartAngle,
horizEndAngle, vertUpperAngle, vertLowerAngle)
# Save the output
outvis.save("c:/sapyexamples/output/visiout1")