主要内容

padarray

填充数组

说明

B = padarray(A,padsize) 填充数组 A,每个维度的填充量由 padsize 指定。padarray 函数用值 0 填充数值或逻辑图像,用类别 <undefined> 填充分类图像。默认情况下,paddarray 在每个维度的第一个元素之前和最后一个元素之后添加填充。

示例

B = padarray(A,padsize,padval) 填充数组 A,其中 padval 指定用于填充元素的常量值或用于复制数组元素的方法。

B = padarray(___,direction)direction 指定的方向上填充 A

示例

全部折叠

填充向量的开头

用填充值 9 在向量的开头添加三个填充元素,得到 4×4 数组。

A = [ 1 2 3 4 ]
A = 1×4

     1     2     3     4

B = padarray(A,3,9,'pre')
B = 4×4

     9     9     9     9
     9     9     9     9
     9     9     9     9
     1     2     3     4

填充二维数组的每个维度

在数组第一个维度的末尾添加三个填充元素,在第二个维度的末尾添加两个填充元素。使用每个维度上最后一个数组元素的值作为填充值。

A = [ 1 2; 3 4 ]
A = 2×2

     1     2
     3     4

B = padarray(A,[3 2],'replicate','post')
B = 5×4

     1     2     2     2
     3     4     4     4
     3     4     4     4
     3     4     4     4
     3     4     4     4

填充三维数组的每个维度

向三维数组的每个维度添加三个填充元素。每个填充元素均包含填充值 0。

首先创建三维数组。

A = [1 2; 3 4];
B = [5 6; 7 8];
C = cat(3,A,B)
C = 
C(:,:,1) =

     1     2
     3     4


C(:,:,2) =

     5     6
     7     8

填充三维数组

D = padarray(C,[3 3],0,'both')
D = 
D(:,:,1) =

     0     0     0     0     0     0     0     0
     0     0     0     0     0     0     0     0
     0     0     0     0     0     0     0     0
     0     0     0     1     2     0     0     0
     0     0     0     3     4     0     0     0
     0     0     0     0     0     0     0     0
     0     0     0     0     0     0     0     0
     0     0     0     0     0     0     0     0


D(:,:,2) =

     0     0     0     0     0     0     0     0
     0     0     0     0     0     0     0     0
     0     0     0     0     0     0     0     0
     0     0     0     5     6     0     0     0
     0     0     0     7     8     0     0     0
     0     0     0     0     0     0     0     0
     0     0     0     0     0     0     0     0
     0     0     0     0     0     0     0     0

输入参数

全部折叠

要填充的数组,指定为任意维度的数值、逻辑或分类数组。

数据类型: single | double | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64 | logical | categorical

添加到每个维度的填充量,指定为由非负整数组成的向量。例如,padsize 值为 [2 3] 会沿第一个维度添加两个填充元素,沿第二个维度添加三个填充元素。

数据类型: double

填充值,指定为数值标量、字符串标量或字符向量。

下表显示数值图像和逻辑图像的填充选项。数值图像和逻辑图像的默认填充值为 0

数值图像和逻辑图像的填充值

描述

示例

数值标量,X

数组边界之外的输入数组值被赋予值 X。如果未指定填充选项,默认值为 0

[314159265][2222222222222222314222215922222652222222222222222]

"symmetric"

数组边界之外的输入数组值是通过沿数组边界对数组进行镜面反射得到。

[314159265][5115995133144113314415115995622655662265565115995]

"replicate"

数组边界之外的输入数组值假定为等于最近的数组边界值。

[314159265][3331444333144433314441115999222655522265552226555]

"circular"

数组边界之外的输入数组值是通过隐式假设输入数组具有周期性来计算的。

[314159265][5915915652652614314315915915652652614314315915915]

下表显示分类图像的填充选项。分类图像的默认填充值为 missing

分类图像的填充值

描述
字符串标量或字符向量用指定类别的元素填充。字符串或字符向量必须对应于图像中的一个有效类别。
missing<undefined> 类别填充。有关详细信息,请参阅 missing

"symmetric"

数组边界之外的输入数组值是通过沿数组边界对数组进行镜面反射得到。

"replicate"

数组边界之外的输入数组值假定为等于最近的数组边界值。

"circular"

数组边界之外的输入数组值是通过隐式假设输入数组具有周期性来计算的。

数据类型: single | double | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64 | logical | char | string

沿每个维度填充数组的方向,指定为下列值之一:

意义

"both"

沿每个维度在第一个元素之前和最后一个数组元素之后填充。

"post"

沿每个维度在最后一个数组元素之后填充。

"pre"

沿每个维度在第一个数组元素之前填充。

数据类型: char | string

输出参量

全部折叠

填充后的数组,以与 A 具有相同数据类型的数组形式返回。

扩展功能

全部展开

版本历史记录

在 R2006a 之前推出