tfmri.layers.MaxPooling3D
tfmri.layers.MaxPooling3D¶
- class MaxPooling3D(*args, **kwargs)[source]¶
- Bases: - keras.layers.pooling.max_pooling3d.MaxPooling3D- Max pooling operation for 3D data (spatial or spatio-temporal). - Note - This layer can be used as a drop-in replacement for tf.keras.layers.MaxPooling3D. However, this one also supports complex-valued pooling. Simply pass - dtype='complex64'or- dtype='complex128'to the layer constructor.- Downsamples the input along its spatial dimensions (depth, height, and width) by taking the maximum value over an input window (of size defined by - pool_size) for each channel of the input. The window is shifted by- stridesalong each dimension.- Args:
- pool_size: Tuple of 3 integers,
- factors by which to downscale (dim1, dim2, dim3). - (2, 2, 2)will halve the size of the 3D input in each dimension.
 - strides: tuple of 3 integers, or None. Strides values. padding: One of - "valid"or- "same"(case-insensitive).- "valid"means no padding.- "same"results in padding evenly to the left/right or up/down of the input such that output has the same height/width dimension as the input.- data_format: A string,
- one of - channels_last(default) or- channels_first. The ordering of the dimensions in the inputs.- channels_lastcorresponds to inputs with shape- (batch, spatial_dim1, spatial_dim2, spatial_dim3, channels)while- channels_firstcorresponds to inputs with shape- (batch, channels, spatial_dim1, spatial_dim2, spatial_dim3). It defaults to the- image_data_formatvalue found in your Keras config file at- ~/.keras/keras.json. If you never set it, then it will be “channels_last”.
 
- Input shape:
- If - data_format='channels_last': 5D tensor with shape:- (batch_size, spatial_dim1, spatial_dim2, spatial_dim3, channels)
- If - data_format='channels_first': 5D tensor with shape:- (batch_size, channels, spatial_dim1, spatial_dim2, spatial_dim3)
 
- Output shape:
- If - data_format='channels_last': 5D tensor with shape:- (batch_size, pooled_dim1, pooled_dim2, pooled_dim3, channels)
- If - data_format='channels_first': 5D tensor with shape:- (batch_size, channels, pooled_dim1, pooled_dim2, pooled_dim3)
 
 - Example: - ``````python depth = 30 height = 30 width = 30 input_channels = 3 - inputs = tf.keras.Input(shape=(depth, height, width, input_channels)) layer = tf.keras.layers.MaxPooling3D(pool_size=3) outputs = layer(inputs) # Shape: (batch_size, 10, 10, 10, 3) - ``- call(inputs)[source]¶
- This is where the layer’s logic lives. - The - call()method may not create state (except in its first invocation, wrapping the creation of variables or other resources in- tf.init_scope()). It is recommended to create state in- __init__(), or the- build()method that is called automatically before- call()executes the first time.- Parameters
- inputs – - Input tensor, or dict/list/tuple of input tensors. The first positional - inputsargument is subject to special rules: -- inputsmust be explicitly passed. A layer cannot have zero- arguments, and - inputscannot be provided via the default value of a keyword argument.- NumPy array or Python scalar values in - inputsget cast as tensors.
- Keras mask metadata is only collected from - inputs.
- Layers are built ( - build(input_shape)method) using shape info from- inputsonly.
- input_speccompatibility is only checked against- inputs.
- Mixed precision input casting is only applied to - inputs. If a layer has tensor arguments in- *argsor- **kwargs, their casting behavior in mixed precision should be handled manually.
- The SavedModel input specification is generated using - inputsonly.
- Integration with various ecosystem packages like TFMOT, TFLite, TF.js, etc is only supported for - inputsand not for tensors in positional and keyword arguments.
 
- *args – Additional positional arguments. May contain tensors, although this is not recommended, for the reasons above. 
- **kwargs – - Additional keyword arguments. May contain tensors, although this is not recommended, for the reasons above. The following optional keyword arguments are reserved: - - training: Boolean scalar tensor of Python boolean indicating- whether the - callis meant for training or inference.- mask: Boolean input mask. If the layer’s- call()method takes a- maskargument, its default value will be set to the mask generated for- inputsby the previous layer (if- inputdid come from a layer that generated a corresponding mask, i.e. if it came from a Keras layer with masking support).
 
 
- Returns
- A tensor or list/tuple of tensors.