Транспонированный 3-D слой свертки
Транспонированный 3-D слой свертки повышает качество трехмерных карт функций.
Этот слой иногда неправильно известен как слой «deconvolution» или «deconv». Этот слой является транспонированием свертки и не выполняет деконволюцию.
Создайте транспонированную свертку 3-D выходов слоя с помощью transposedConv3dLayer
.
FilterSize
- Высота, ширина и глубина фильтровВысота, ширина и глубина фильтров, заданная в виде вектора [h w d]
из трех положительных целых чисел, где h
- высота, w
- ширина, и d
- глубина. FilterSize
определяет размер локальных областей, с которыми нейроны соединяются во входе.
При создании слоя можно задать FilterSize
в качестве скаляра для использования того же значения высоты, ширины и глубины.
Пример:
[5 5 5] задает фильтры с высотой, шириной и глубиной 5.
NumFilters
- Количество фильтровКоличество фильтров, заданное в виде положительного целого числа. Это количество соответствует количеству нейронов в сверточном слое, которые соединяются с одной и той же областью на входе. Этот параметр определяет количество каналов (функции) в выходе сверточного слоя.
Пример:
96
Stride
- Размер шага для обхода входа[1 1 1]
(по умолчанию) | вектор из трех положительных целых чиселРазмер шага для прохождения входа в трёх размерностях, заданный как вектор [a b c]
из трех положительных целых чисел, где a
- вертикальный размер шага, b
- горизонтальный размер шага, и c
- размер шага по глубине. При создании слоя можно задать Stride
в качестве скаляра для использования того же значения для размеров шагов во всех трех направлениях.
Пример:
[2 3 1] задает размер шага по вертикали 2, размер шага по горизонтали 3 и размер шага по глубине 1.
CroppingMode
- Метод определения размера кадрирования'manual'
(по умолчанию) | 'same'
Метод для определения размера кадрирования, заданный как 'manual'
или 'same'
.
Программа автоматически устанавливает значение CroppingMode
на основе 'Cropping'
значение, заданное при создании слоя.
Если вы задаете 'Cropping'
опция для числового значения, затем программное обеспечение автоматически устанавливает CroppingMode
свойство слоя, чтобы 'manual'
.
Если вы задаете 'Cropping'
опция для 'same'
, затем программное обеспечение автоматически устанавливает CroppingMode
свойство слоя, чтобы 'same'
и установите обрезку так, чтобы размер выхода равнялся inputSize .* Stride
, где inputSize
- высота, ширина и глубина входа слоя.
Чтобы задать размер кадрирования, используйте 'Cropping'
опция transposedConv3dLayer
.
CroppingSize
- Сокращение размера выходного сигнала[0 0 0;0 0 0]
(по умолчанию) | матрица неотрицательных целых чиселСокращение размера выхода, заданное как матрица неотрицательных целых чисел [t l f; b r bk]
, t
, l
, f
, b
, r
, bk
- количество урожая из верхней части, левой, передней, нижней, правой и задней частей входа, соответственно.
Чтобы задать размер кадрирования вручную, используйте 'Cropping'
опция transposedConv2dLayer
.
Пример:
[0 1 0 1 0 1]
NumChannels
- Количество каналов для каждого фильтра'auto'
(по умолчанию) | целое числоКоличество каналов для каждого фильтра, заданное 'auto'
или целое число.
Этот параметр должен быть равен количеству каналов входа в этот сверточный слой. Для примера, если вход является цветным изображением, то количество каналов для ввода должно быть 3. Если количество фильтров для сверточного слоя перед текущим слоем составляет 16, то количество каналов для этого слоя должно быть 16.
WeightsInitializer
- Функция для инициализации весов'glorot'
(по умолчанию) | 'he'
| 'narrow-normal'
| 'zeros'
| 'ones'
| указатель на функциюФункция для инициализации весов, заданная как одно из следующего:
'glorot'
- Инициализируйте веса с помощью инициализатора Glorot [1] (также известного как инициализатор Xavier). Инициализатор Glorot независимо выбирает из равномерного распределения с нулем среднего и отклонением 2/(numIn + numOut)
, где numIn = FilterSize(1)*FilterSize(2)*FilterSize(3)*NumChannels
и numOut = FilterSize(1)*FilterSize(2)*FilterSize(3)*NumFilters
.
'he'
- Инициализируйте веса с помощью инициализатора He [2]. Инициализатор He производит выборки из нормального распределения с нулем среднего и отклонением 2/numIn
, где numIn = FilterSize(1)*FilterSize(2)*FilterSize(3)*NumChannels
.
'narrow-normal'
- Инициализируйте веса путем независимой выборки из нормального распределения с нулевым средним и стандартным отклонением 0,01.
'zeros'
- Инициализируйте веса с нулями.
'ones'
- Инициализируйте веса с таковыми.
Указатель на функцию - Инициализируйте веса с помощью пользовательской функции. Если вы задаете указатель на функцию, то функция должна иметь вид weights = func(sz)
, где sz
- размер весов. Для получения примера смотрите Задать Пользовательскую Функцию Инициализации Веса.
Слой инициализирует веса только тогда, когда Weights
свойство пустое.
Типы данных: char
| string
| function_handle
BiasInitializer
- Функция для инициализации смещения'zeros'
(по умолчанию) | 'narrow-normal'
| 'ones'
| указатель на функциюФункция для инициализации смещения, заданная как одно из следующего:
'zeros'
- Инициализируйте смещение с нулями.
'ones'
- Инициализируйте смещение с таковые.
'narrow-normal'
- Инициализируйте смещение путем независимой выборки из нормального распределения с нулевым средним и стандартным отклонением 0,01.
Указатель на функцию - Инициализируйте смещение с помощью пользовательской функции. Если вы задаете указатель на функцию, то функция должна иметь вид bias = func(sz)
, где sz
- размер смещения.
Слой инициализирует смещение только тогда, когда Bias
свойство пустое.
Типы данных: char
| string
| function_handle
Weights
- Веса слоев[]
(по умолчанию) | числовой массивВеса слоев для транспонированного сверточного слоя, заданные как числовой массив.
Веса слоев являются настраиваемыми параметрами. Можно задать начальное значение для весов непосредственно с помощью Weights
свойство слоя. При обучении сети, если Weights
свойство слоя непусто, тогда trainNetwork
использует Weights
свойство как начальное значение. Если на Weights
свойство пустое, тогда trainNetwork
использует инициализатор, заданный как WeightsInitializer
свойство слоя.
Во время обучения Weights
является FilterSize(1)
-by- FilterSize(2)
-by- FilterSize(3)
-by- NumFilters
-by- NumChannels
массив.
Типы данных: single
| double
Bias
- Смещения слоев[]
(по умолчанию) | числовой массивСмещения слоев для транспонированного сверточного слоя, заданные как числовой массив.
Смещения слоя являются настраиваемыми параметрами. При обучении сети, если Bias
непусто, тогда trainNetwork
использует Bias
свойство как начальное значение. Если Bias
пуст, тогда trainNetwork
использует инициализатор, заданный как BiasInitializer
.
Во время обучения Bias
1 на 1 на 1 NumFilters
массив.
Типы данных: single
| double
WeightLearnRateFactor
- Коэффициент скорости обучения для весовКоэффициент скорости обучения для весов, заданный как неотрицательный скаляр.
Программа умножает этот коэффициент на глобальный темп обучения, чтобы определить скорость обучения для весов на этом слое. Для примера, если WeightLearnRateFactor
равен 2, тогда скорость обучения для весов на этом слое в два раза превышает текущую глобальную скорость обучения. Программа определяет глобальную скорость обучения на основе настроек, заданных в trainingOptions
функция.
Пример: 2
BiasLearnRateFactor
- Коэффициент скорости обучения для смещенийКоэффициент скорости обучения для смещений, заданный как неотрицательный скаляр.
Программа умножает этот коэффициент на глобальную скорость обучения, чтобы определить скорость обучения для смещений на этом слое. Для примера, если BiasLearnRateFactor
равен 2, тогда скорость обучения для смещений в слое в два раза превышает текущую глобальную скорость обучения. Программа определяет глобальную скорость обучения на основе настроек, заданных в trainingOptions
функция.
Пример: 2
WeightL2Factor
- L2 коэффициент регуляризации для весовL2 регуляризации для весов, заданный как неотрицательный скаляр.
Программа умножает этот коэффициент на глобальный коэффициент регуляризации L2, чтобы определить L2 регуляризацию для весов на этом слое. Для примера, если WeightL2Factor
равен 2, тогда L2 регуляризация для весов в этом слое в два раза превышает глобальный коэффициент регуляризации L2. Можно задать глобальный коэффициент регуляризации L2 с помощью trainingOptions
функция.
Пример: 2
BiasL2Factor
- L2 коэффициент регуляризации для смещенийL2 регуляризации для смещений, заданный как неотрицательный скаляр.
Программа умножает этот коэффициент на глобальный коэффициент регуляризации L2, чтобы определить L2 регуляризацию для смещений на этом слое. Для примера, если BiasL2Factor
равен 2, тогда L2 регуляризация для смещений в этом слое в два раза превышает глобальный коэффициент регуляризации L2. Можно задать глобальный коэффициент регуляризации L2 с помощью trainingOptions
функция.
Пример: 2
Name
- Имя слоя''
(по умолчанию) | символьный вектор | строковый скаляр
Имя слоя, заданное как вектор символов или строковый скаляр. Чтобы включить слой в график слоев, необходимо задать непустое уникальное имя слоя. Если вы обучаете последовательную сеть с слоем и Name
установлено в ''
затем программа автоматически присваивает слою имя во время обучения.
Типы данных: char
| string
NumInputs
- Количество входовКоличество входов слоя. Этот слой принимает только один вход.
Типы данных: double
InputNames
- Входные имена{'in'}
(по умолчанию)Входные имена слоя. Этот слой принимает только один вход.
Типы данных: cell
NumOutputs
- Количество выходовКоличество выходов слоя. Этот слой имеет только один выход.
Типы данных: double
OutputNames
- Выходные имена{'out'}
(по умолчанию)Выходные имена слоя. Этот слой имеет только один выход.
Типы данных: cell
Создайте транспонированный 3-D сверточный слой с 32 фильтрами, каждый с высотой, шириной и глубиной 11. Используйте шаг 4 в горизонтальном и вертикальном направлениях и 2 по глубине.
layer = transposedConv3dLayer(11,32,'Stride',[4 4 2])
layer = TransposedConvolution3DLayer with properties: Name: '' Hyperparameters FilterSize: [11 11 11] NumChannels: 'auto' NumFilters: 32 Stride: [4 4 2] CroppingMode: 'manual' CroppingSize: [2x3 double] Learnable Parameters Weights: [] Bias: [] Show all properties
[1] Глорот, Ксавьер и Йошуа Бенгио. «Понимание сложности обучения нейронных сетей с глубоким Feedforward». В работе тринадцатой Международной конференции по искусственному интеллекту и статистике, 249-356. Сардиния, Италия: AISTATS, 2010.
[2] He, Kaiming, Xiangyu Zhang, Shaoqing Ren, and Jian Sun. «Delving Deep Into Rectifiers: Overpassing Human-Level Performance on ImageNet Classification». В работе Международной конференции IEEE по компьютерному зрению 2015 года, 1026-1034. Вашингтон, округ Колумбия: IEEE Компьютерное Зрение Society, 2015.
averagePooling3dLayer
| convolution3dLayer
| maxPooling3dLayer
| transposedConv2dLayer
| transposedConv3dLayer
У вас есть измененная версия этого примера. Вы хотите открыть этот пример с вашими правками?
1. Если смысл перевода понятен, то лучше оставьте как есть и не придирайтесь к словам, синонимам и тому подобному. О вкусах не спорим.
2. Не дополняйте перевод комментариями “от себя”. В исправлении не должно появляться дополнительных смыслов и комментариев, отсутствующих в оригинале. Такие правки не получится интегрировать в алгоритме автоматического перевода.
3. Сохраняйте структуру оригинального текста - например, не разбивайте одно предложение на два.
4. Не имеет смысла однотипное исправление перевода какого-то термина во всех предложениях. Исправляйте только в одном месте. Когда Вашу правку одобрят, это исправление будет алгоритмически распространено и на другие части документации.
5. По иным вопросам, например если надо исправить заблокированное для перевода слово, обратитесь к редакторам через форму технической поддержки.