** (Power) operator

Доступно с лицензией Spatial Analyst.

Доступно с лицензией Image Analyst.

Краткая информация

Возводит в степень значения ячейки растра, где степень равна значениям в другом растре.

Иллюстрация

Иллюстрация Степень
OutRas = Raster("InRas1") ** 2

Обсуждение

При использовании оператора со входным растром на выходе также будет растр. Если же все входные данные являются числами, на выходе также будет число.

Если в выражении используется несколько операторов, их необязательно выполнять в порядке слева направо. Оператор с наивысшим значением приоритета будет выполнен первым. Более подробно см. таблицу приоритета операторов в разделе Работа с операторами в алгебре карт. Порядок выполнения операторов меняется с помощью скобок.

Выходные значения всегда хранятся как значения с плавающей точкой, независимо от типа входных значений.

Другой способ выполнить сложение – a **= b, что иным способом может быть записано как a = a ** b.

Если оба входных растра являются одноканальными или на входе имеется константа, на выходе получится одноканальный растр.

Если оба входных растра являются многоканальными, оператор будет выполнен для каждого канала, а выходной растр будет многоканальным. Число каналов всех многоканальных растров должно быть одинаковым.

Если один из входных растров является многоканальным, а другие входные данные - константами, оператор выполнится с постоянным значением для каждого канала многоканального входного растра, а выходной растр будет многоканальным.

Если все входные данные являются многомерными растрами с одинаковым количеством переменных, оператор будет выполнен для всех срезов с одинаковым значением измерения, а на выходе будет получен многомерный растр. У переменных во входных данных должны быть одинаковые или общие размерности.

Если у обоих входных данных одна переменная, но разные имена, установите False для среды геообработки Сопоставить многомерную переменную, чтобы выполнить операцию.

Если одними из входных данных является многомерный растр, а другие - константой, оператор будет выполнен для всех срезов для всех переменных с постоянным значением, и на выходе будет получен многомерный растр.

Параметры

ОперандОписаниеТип данных
in_raster_or_constant1

Входные значения, которые будут возведены в степень, заданную вторыми входными данными.

Если первый набор входных значений является растром, а второй – скаляром, то выходной растр создается с каждым значением входного растра, возведённом в степень значения скаляра.

Raster Layer | Constant
in_raster_or_constant2

Входные данные, определяющие степень, в которую будут возведены значения первых входных данных.

Если первый набор входных значений является скаляром, а второй – растром, то выходной растр создается со значением скаляра, возведённом в степень каждого значения входного растра.

Raster Layer | Constant

Пример кода

** (Степень) Пример 1 (окно Python)

В этом примере используются значения второго входного растра как степень, в которую будут возводиться значения первого входного растра.

import arcpy
from arcpy import env
from arcpy.sa import *
env.workspace = "C:/sapyexamples/data"
outPower = Raster("degs") ** Raster("cost")
outPower.save("C:/sapyexamples/output/outpower.img")
** (Степень), пример 2 (автономный скрипт)

В этом примере используются значения второго входного растра как степень, в которую будут возводиться значения первого входного растра.

# Name: Op_Power_Ex_02.py
# Description: Raises the cells in a raster to the power of the values
#              found in another raster
# 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 = Raster("degs")
inRaster2 = Raster("cost")

# Execute Power
outPower = inRaster1 ** inRaster2

# Save the output 
outPower.save("C:/sapyexamples/output/outpower")

Связанные разделы