蚕食 (Spatial Analyst)

需要 Spatial Analyst 许可。

摘要

用最邻近点的值替换掩膜范围内的栅格像元的值。

了解有关蚕食工作原理的详细信息

插图

蚕食图示
OutRas = Nibble(InRas1, Mask_Ras)

使用情况

  • 通过 Nibble 工具可将最近邻域的值分配给栅格中的所选区域。可使用该工具将几个单独的像元替换为紧邻的值。掩膜区域越大,可替换的带状像元越大。

    通用应用程序用于编辑某栅格中已知数据存在错误的区域。

  • 输入掩膜栅格中值为 NoData 的像元定义哪些像元被蚕食。输入栅格中任何不在掩膜区域内的位置均不会被蚕食,因此,它们的输出值和输入值相同。

    输入栅格中不在掩膜内的 NoData 像元不会被蚕食。无论两个 NoData 参数设置为何,这些像元都将保持为 NoData。

  • 该工具支持并行处理。如果您的计算机具有多个处理器或处理器具有多个内核,则会获得更好的性能,特别是处理较大数据集时。使用 Spatial Analyst 进行并行处理帮助主题提供了有关此功能及其配置方法的详细信息。

    使用并行处理时,将写入临时数据以管理正在处理的数据区段。默认的临时文件夹位于您的本地 C 驱动器上。您可以通过设置名为 TempFolders 的系统环境变量并指定要使用的文件夹路径(例如,E:\RasterCache),来控制此文件夹的位置。如果您具有计算机管理权限,还可以使用注册表项(例如,[HKEY_CURRENT_USER\SOFTWARE\ESRI\ArcGISPro\Raster])。

    默认情况下,此工具将使用可用内核数的 50%。如果输入数据大小小于 5,000 * 5,000 个像元,则会使用更少的内核。您可以控制该工具用于并行处理因子环境的内核数。

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

参数

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

将被蚕食的输入栅格。

输入栅格可以是整型,也可以是浮点型。

Raster Layer
输入栅格掩膜

用作掩膜的栅格。

掩膜栅格中的 NoData 像元能够识别输入栅格中将被蚕食或被最近邻域的值替换的像元。

掩膜栅格可以是整型,也可以是浮点型。

Raster Layer
如果 NoData 值是最近的相邻要素,则使用这些值
(可选)

指定是否允许将输入栅格中的 NoData 像元蚕食为由掩膜栅格定义的区域。

  • 选中 - 可以将 NoData 和数据值蚕食为在掩膜栅格中定义的区域。如果输入栅格中的 NoData 值是最邻近点,则可自由地将其蚕食掉为掩膜中定义的区域。这是默认设置。
  • 未选中 - 只能将数据值蚕食为在掩膜栅格中定义的区域。即使输入栅格中的 NoData 值是最邻近点,也不允许将其蚕食为掩膜栅格中定义的区域。
Boolean
蚕食 NoData 像元
(可选)

指定输入栅格中处于掩膜内的 NoData 像元在输出栅格中是否保持为 NoData。

  • 未选中 - 输入栅格中处于掩膜内的 NoData 像元在输出中将保持为 NoData。这是默认设置。
  • 选中 - 可以将输入栅格中处于掩膜内的 NoData 像元蚕食为有效的输出像元值。
Boolean
输入区域栅格数据
(可选)

输入区域栅格。在每个区域中,掩膜内的输入像元仅会被同一区域内的最近像元值替换。

区域是指栅格中具有相同值的所有像元,无论这些像元是否相连。输入区域图层定义了区域的形状、值和位置。区域栅格可以是整型,也可以是浮点型。

Raster Layer

返回值

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

输出已蚕食的栅格。

识别的输入像元将被用其最邻近点的值进行替换。

如果 in_raster 为整型,则输出栅格将为整型。如果输入栅格为浮点型,则输出栅格也为浮点型。

Raster

Nibble(in_raster, in_mask_raster, {nibble_values}, {nibble_nodata}, {in_zone_raster})
名称说明数据类型
in_raster

将被蚕食的输入栅格。

输入栅格可以是整型,也可以是浮点型。

Raster Layer
in_mask_raster

用作掩膜的栅格。

掩膜栅格中的 NoData 像元能够识别 in_raster 中将被蚕食或被最近邻域的值替换的像元。

掩膜栅格可以是整型,也可以是浮点型。

Raster Layer
nibble_values
(可选)

指定是否允许将输入栅格中的 NoData 像元蚕食为由掩膜栅格定义的区域。

  • ALL_VALUES可以将 NoData 和数据值蚕食为在掩膜栅格中定义的区域。如果输入栅格中的 NoData 值是最邻近点,则可自由地将其蚕食掉为掩膜中定义的区域。这是默认设置。
  • DATA_ONLY只能将数据值蚕食为在掩膜栅格中定义的区域。即使输入栅格中的 NoData 值是最邻近点,也不允许将其蚕食为掩膜栅格中定义的区域。
Boolean
nibble_nodata
(可选)

指定输入栅格中处于掩膜内的 NoData 像元在输出栅格中是否保持为 NoData。

  • PRESERVE_NODATA 输入栅格中处于掩膜内的 NoData 像元在输出中将保持为 NoData。这是默认设置。
  • PROCESS_NODATA可以将输入栅格中处于掩膜内的 NoData 像元蚕食为有效的输出像元值。
Boolean
in_zone_raster
(可选)

输入区域栅格。在每个区域中,掩膜内的输入像元仅会被同一区域内的最近像元值替换。

区域是指栅格中具有相同值的所有像元,无论这些像元是否相连。输入区域图层定义了区域的形状、值和位置。区域栅格可以是整型,也可以是浮点型。

Raster Layer

返回值

名称说明数据类型
out_raster

输出已蚕食的栅格。

识别的输入像元将被用其最邻近点的值进行替换。

如果 in_raster 为整型,则输出栅格将为整型。如果输入栅格为浮点型,则输出栅格也为浮点型。

Raster

代码示例

Nibble 示例 1(Python 窗口)

此例使用由输入栅格的最邻近点确定的值来替换由输入掩膜所识别的像元。

import arcpy
from arcpy import env
from arcpy.sa import *
env.workspace = "C:/sapyexamples/data"
nibbleOut = Nibble("land", "snow", "DATA_ONLY")
nibbleOut.save("C:/sapyexamples/output/nibbleout")
Nibble 示例 2(独立脚本)

此例使用由输入栅格的最邻近点确定的值来替换由输入掩膜所识别的像元。

# Name: Nibble_Ex_02.py
# Description: Replaces cells of a raster corresponding to a mask 
#              with the values of the nearest neighbors.
# 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 = "land"
inMask = "snow"

# Execute Nibble
nibbleOut = Nibble(inRaster, inMask, "ALL_VALUES")

# Save the output 
nibbleOut.save("C:/sapyexamples/output/outnibble")

许可信息

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

相关主题