prod
数组元素的乘积
语法
说明
如果
A
是向量,则prod(A)
返回元素的乘积。如果
A
为非空矩阵,则prod(A)
将A
的各列视为向量,并返回一个包含每列乘积的行向量。如果
A
为 0×0 空矩阵,prod(A)
返回1
。如果
A
为多维数组,则prod(A)
沿第一个非单一维度运算并返回乘积数组。此维度中B
的大小将减少至1
,而所有其他维度的大小仍与在A
中相同。如果
A
是表或时间表,则prod(A)
返回每个变量乘积的单行表。 (自 R2023a 起)
如果输入 A
为 single
类型,则 prod
会计算并将 B
以 single
类型返回。如果为任何其他数值和逻辑数据类型,prod
会计算并将 B
以 double
类型返回。
示例
每列中元素的乘积
创建其元素与其线性索引对应的 3×3 数组。
A=[1:3:7;2:3:8;3:3:9]
A = 3×3
1 4 7
2 5 8
3 6 9
计算每列中元素的乘积。第一个维度的长度为 1,第二个维度的长度与 size(A,2)
匹配。
B = prod(A)
B = 1×3
6 120 504
逻辑输入的乘积
创建一个逻辑值数组。
A = [true false; true true]
A = 2x2 logical array
1 0
1 1
计算每列中元素的乘积。
B = prod(A)
B = 1×2
1 0
输出的类型为 double
。
class(B)
ans = 'double'
每行中元素的乘积
创建其元素与其线性索引对应的 3×3 数组。
A=[1:3:7;2:3:8;3:3:9]
A = 3×3
1 4 7
2 5 8
3 6 9
计算每行中元素的乘积,并将第二个维度的长度减少到 1。第一个维度的长度与 size(A,1)
匹配,第二个维度的长度为 1。
dim = 2; B = prod(A,dim)
B = 3×1
28
80
162
数组页的乘积
创建一个三维数组并计算每页数据(行和列)的乘积。
A(:,:,1) = [2 4; -2 1]; A(:,:,2) = [1 2; -5 3]; A(:,:,3) = [4 4; 1 -3]; B1 = prod(A,[1 2])
B1 = B1(:,:,1) = -16 B1(:,:,2) = -30 B1(:,:,3) = -48
要计算一个数组的所有维度上的乘积,可以在向量维参量中指定每个维度,或使用 "all"
选项。
B2 = prod(A,[1 2 3])
B2 = -23040
Ball = prod(A,"all")
Ball = -23040
将单精度输入作为双精度处理
创建一个由单精度值组成的 3×3 数组。
A = single([1200 1500 1800; 1300 1600 1900; 1400 1700 2000])
A = 3x3 single matrix
1200 1500 1800
1300 1600 1900
1400 1700 2000
执行双精度的乘法来计算每行中元素的乘积。
B = prod(A,2,"double")
B = 3×1
109 ×
3.2400
3.9520
4.7600
输出为双精度值。
class(B)
ans = 'double'
整数数据类型的输入和输出
创建一个由 8 位无符号整数组成的 3×3 数组。
A = uint8([1:3:7;2:3:8;3:3:9])
A = 3x3 uint8 matrix
1 4 7
2 5 8
3 6 9
计算每列中本身为 uint8
的元素的乘积。
B = prod(A,"native")
B = 1x3 uint8 row vector
6 120 255
结果为一个 8 位无符号整数数组。
class(B)
ans = 'uint8'
排除缺失值的乘积
创建一个包含 NaN
值的矩阵。
A = [1.77 -0.005 NaN -2.95; NaN 0.34 NaN 0.19]
A = 2×4
1.7700 -0.0050 NaN -2.9500
NaN 0.3400 NaN 0.1900
计算矩阵的乘积,不包括 NaN
值。对于包含任一 NaN
值的矩阵列,prod
使用非 NaN
元素进行计算。对于包含的值都是 NaN
的矩阵列,乘积为 1。
B = prod(A,"omitnan")
B = 1×4
1.7700 -0.0017 1.0000 -0.5605
输入参数
A
— 输入数组
向量 | 矩阵 | 多维数组 | 表 | 时间表
输入数组,指定为向量、矩阵、多维数组、表或时间表。
数据类型: double
| single
| int8
| int16
| int32
| int64
| uint8
| uint16
| uint32
| uint64
| logical
| table
| timetable
复数支持: 是
dim
— 沿其运算的维度
正整数标量
沿其运算的维度,指定为正整数标量。如果不指定维度,则默认为第一个大于 1 的数组维度。
维度 dim
表示长度减至 1
的维度。size(B,dim)
为 1
,而所有其他维度的大小保持不变。
以一个二维输入数组 A
为例。
如果
dim = 1
,则prod(A,1)
返回包含每一列中元素的乘积的行向量。如果
dim = 2
,则prod(A,2)
返回包含每一行中元素的乘积的列向量。
当 dim
大于 ndims(A)
时,prod
返回 A
。
数据类型: double
| single
| int8
| int16
| int32
| int64
| uint8
| uint16
| uint32
| uint64
vecdim
— 维度向量
正整数向量
维度向量,指定为正整数向量。每个元素代表输入数组的一个维度。指定的操作维度的输出长度为 1,而其他保持不变。
以 2×3×3 输入数组 A
为例。然后 prod(A,[1 2])
返回一个 1×1×3 数组,其元素是 A
的每个页面的乘积。
数据类型: double
| single
| int8
| int16
| int32
| int64
| uint8
| uint16
| uint32
| uint64
outtype
— 输出类
"default"
(默认) | "double"
| "native"
输出类,指定为 "default"
、"double"
或 "native"
,用于定义输出 B
的数据类型。
outtype | 输出数据类型 |
---|---|
"default" | double ,除非输入数据类型为 single 、table 或 timetable 。在这种情况下,输出数据类型分别为 single 或 table 。 |
"double" | double ,除非输入数据类型为 table 或 timetable 。在这种情况下,输出数据类型为 table 。 |
"native" | 与输入数组 A 的数据类型相同,除非输入数据类型为 timetable 。在这种情况下,输出数据类型为 table 。 |
nanflag
— 缺失值条件
"includemissing"
(默认) | "includenan"
| "omitmissing"
| "omitnan"
缺失值条件,指定为下列值之一:
"includemissing"
或"includenan"
- 在计算乘积时包括A
中的NaN
值。如果运算维度中的任一元素是NaN
,则B
中的对应元素也是NaN
。"includemissing"
和"includenan"
具有相同的行为。"omitmissing"
或"omitnan"
- 忽略A
中的NaN
值,并基于较少的点计算乘积。如果运算维度中的所有元素均为NaN
,则B
中的对应元素为 1。"omitmissing"
和"omitnan"
具有相同的行为。
输出参量
B
— 乘积数组
标量 | 向量 | 矩阵 | 多维数组 | 表
乘积数组,以标量、向量、矩阵、多维数组或表形式返回。
B
的类如下所示:
如果
outtype
参量指定为"default"
或未使用它并且输入不是
single
、table
或timetable
,则输出为double
。并且输入为
single
,则输出为single
。并且输入为
table
或timetable
,则输出为table
。
如果
outtype
参量指定"double"
,则输出为double
,这与输入数据类型无关,除非输入为table
或timetable
。如果
outtype
参量指定"native"
,则输出与输入具有相同的数据类型,除非输入为timetable
。在这种情况下,输出为table
。
详细信息
第一个非单一维度
第一个非单一维度是其大小不等于 1
的数组的第一维度。
例如:
如果
X
为 1×n 的行向量,则第二个维度是X
的第一个非单一维度。如果
X
为 1×0×n 的空数组,则第二个维度是X
的第一个非单一维度。如果
X
为 1×1×3 的数组,则第三个维度是X
的第一个非单一维度。
扩展功能
tall 数组
对行数太多而无法放入内存的数组进行计算。
此函数完全支持 tall 数组。有关详细信息,请参阅 tall 数组。
C/C++ 代码生成
使用 MATLAB® Coder™ 生成 C 代码和 C++ 代码。
用法说明和限制:
如果提供
dim
,则它必须为常量。请参阅Variable-Sizing Restrictions for Code Generation of Toolbox Functions (MATLAB Coder)。
GPU 代码生成
使用 GPU Coder™ 为 NVIDIA® GPU 生成 CUDA® 代码。
用法说明和限制:
如果提供
dim
,则它必须为常量。
基于线程的环境
使用 MATLAB® backgroundPool
在后台运行代码或使用 Parallel Computing Toolbox™ ThreadPool
加快代码运行速度。
此函数完全支持基于线程的环境。有关详细信息,请参阅在基于线程的环境中运行 MATLAB 函数。
GPU 数组
通过使用 Parallel Computing Toolbox™ 在图形处理单元 (GPU) 上运行来加快代码执行。
用法说明和限制:
"native"
选项不支持 64 位整数。未定义
prod
运算中的乘积顺序。因此,对 GPU 数组执行prod
运算与对相应的数值数组执行prod
运算所返回的值可能不完全相同。
有关详细信息,请参阅在 GPU 上运行 MATLAB 函数 (Parallel Computing Toolbox)。
分布式数组
使用 Parallel Computing Toolbox™ 在集群的组合内存中对大型数组进行分区。
用法说明和限制:
未定义
prod
运算中的乘积顺序。因此,对分布式数组执行prod
运算与对相应的数值数组执行prod
运算所返回的值可能不完全相同。当A
是有符号整数类型且其乘积在本机累积时,差异可能相当大。
有关详细信息,请参阅使用分布式数组运行 MATLAB 函数 (Parallel Computing Toolbox)。
版本历史记录
在 R2006a 之前推出R2023a: 指定缺失值条件
在使用 "includemissing"
或 "omitmissing"
选项计算乘积时,包括还是忽略输入数组中的缺失值。这些选项的行为分别与 "includenan"
和 "omitnan"
选项相同。
R2023a: 直接对表和时间表执行计算
prod
函数可以对表或时间表中的所有变量执行计算,而无需通过索引访问这些变量。所有变量都必须具有支持计算的数据类型。有关详细信息,请参阅Direct Calculations on Tables and Timetables。
R2018b: 对多个维度执行运算
一次对输入数组的多个维度执行运算。指定一个由运算维度组成的向量,或指定 "all"
选项以对所有数组维度执行运算。
MATLAB 命令
您点击的链接对应于以下 MATLAB 命令:
请在 MATLAB 命令行窗口中直接输入以执行命令。Web 浏览器不支持 MATLAB 命令。
Select a Web Site
Choose a web site to get translated content where available and see local events and offers. Based on your location, we recommend that you select: .
You can also select a web site from the following list:
How to Get Best Site Performance
Select the China site (in Chinese or English) for best site performance. Other MathWorks country sites are not optimized for visits from your location.
Americas
- América Latina (Español)
- Canada (English)
- United States (English)
Europe
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom (English)