求模 (Spatial Analyst)

需要 Spatial Analyst 许可。

获得 Image Analyst 许可后可用。

摘要

逐个像元地求出第一个栅格数据除以第二个栅格数据的余数(模)。

插图

“求模”图示
OutRas = Mod(InRas1, InRas2)

使用情况

  • 使用此工具时输入的顺序很重要。

  • 求模假设它的两个输入都是整数。 如果有任何输入不是整数,则将通过截断将这些输入转换为整数。 输出值始终是整数。

  • 任何被 0 求模(除)的值在输出上均被赋予 NoData。 因此,在第二个输入上值为 0 或 NoData 的任一位置在输出上的对应位置都会返回 NoData。

  • 如果第二个输入值(除数)大于第一个输入值(被除数),则输出将与第一个输入相同。 例如,如果要用值 8 除以值 10,则整数除法计算将返回输入值 8 作为余数。

  • 如果两个输入都是单波段栅格,或者输入之一是常量,则输出将是单波段栅格。

  • 如果两个输入均为多波段栅格,则该工具将针对一个输入中的每个波段执行运算,并且输出将为多波段栅格。 每个多波段输入中的波段数必须相同。

  • 如果输入之一是多波段栅格,而另一个输入是常量,则该工具将使用多波段输入中每个波段的常量值执行运算,而输出将为多波段栅格。

  • 如果所有输入均为具有相同数量变量的多维栅格数据,则该工具将对具有相同维度值的所有剖切片执行运算。 输出将是 CRF 格式的多维栅格。 输入中的变量必须至少具有一个常见维度和一个常见维度值以供此工具进行处理,否则将发生错误。

    如果所有输入均具有一个变量但名称不同,请在运行工具之前取消选中匹配多维变量地理处理环境(在 Python 中设置为 arcpy.env.matchMultidimensionalVariable = False)。

    如果其中一个输入为多维栅格,而其他输入为常量,则该工具将使用常量值,对所有变量的所有切片执行运算,并且输出将为多维栅格。

  • 在“地图代数”中,此工具的等价运算符为“%”(链接)。

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

参数

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

分子输入。

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

Raster Layer; Constant
输入栅格数据或常量值 2

分母输入。

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

Raster Layer; Constant

返回值

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

输出栅格。

像元值为第一个输入的值除以第二个输入的值的余数。

Raster

Mod(in_raster_or_constant1, in_raster_or_constant2)
名称说明数据类型
in_raster_or_constant1

分子输入。

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

Raster Layer; Constant
in_raster_or_constant2

分母输入。

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

Raster Layer; Constant

返回值

名称说明数据类型
out_raster

输出栅格。

像元值为第一个输入的值除以第二个输入的值的余数。

Raster

代码示例

Mod 示例 1(Python 窗口)

此例返回第一个栅格的像元除以第二个栅格的像元的余数(模)值。

import arcpy
from arcpy import env
from arcpy.sa import *
env.workspace = "C:/sapyexamples/data"
outMod = Mod("degs", "negs")
outMod.save("C:/sapyexamples/output/outmod.tif")
Mod 示例 2(独立脚本)

此例返回第一个栅格的像元除以第二个栅格的像元的余数(模)值。

# Name: Mod_Ex_02.py
# Description: Finds the remainder of the first raster when divided by
#              the second raster on a cell-by-cell basis
# 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 Mod
outMod = Mod(inRaster1, inRaster2)

# Save the output 
outMod.save("C:/sapyexamples/output/outmod")

许可信息

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

相关主题