来源:https://ww2.mathworks.cn/help/matlab/ref/sum.html?searchHighlight=sum&s_tid=doc_srchtitle#btv6ok6-1-dim

sum

数组元素总和

全页折叠
 

说明

示例

S = sum(A) 返回 A 沿大小不等于 1 的第一个数组维度的元素之和。

  • 如果 A 是向量,则 sum(A) 返回元素之和。

  • 如果 A 是矩阵,则 sum(A) 将返回包含每列总和的行向量。

  • 如果 A 是多维数组,则 sum(A) 沿大小不等于 1 的第一个数组维度计算,并将这些元素视为向量。此维度会变为 1,而所有其他维度的大小保持不变。

示例

S = sum(A,'all') 计算 A 的所有元素的总和。此语法适用于 MATLAB R2018b 及更高版本。

示例

S = sum(A,dim) 沿维度 dim 返回总和。例如,如果 A 为矩阵,则 sum(A,2) 是包含每一行总和的列向量。

示例

S = sum(A,vecdim) 根据向量 vecdim 中指定的维度对 A 的元素求和。例如,如果 A 是矩阵,则 sum(A,[1 2])A 中所有元素的总和,因为矩阵的每个元素包含在由维度 1 和 2 定义的数组切片中。

示例

S = sum(___,outtype) 使用上述语法中的任何输入参数返回指定数据类型的总和。outtype 可以是 'default''double''native'

示例

S = sum(___,nanflag) 指定在上述任意语法的计算中包括还是忽略 NaN 值。sum(A,'includenan') 会在计算中包括所有 NaN 值,而 sum(A,'omitnan') 则忽略这些值。

 

示例

全部折叠

向量元素的总和

尝试此示例

View MATLAB Command

创建一个向量并计算各个元素的总和。

A = 1:10;
S = sum(A)
S = 55
 
 

矩阵列总和

尝试此示例

View MATLAB Command

创建一个矩阵并计算每列中元素的总和。

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

     1     3     2
4 2 5
6 1 4
S = sum(A)
S = 1×3

    11     6    11
 
 

矩阵行总和

尝试此示例

View MATLAB Command

创建一个矩阵并计算每行中元素的总和。

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

     1     3     2
4 2 5
6 1 4
S = sum(A,2)
S = 3×1

     6
11
11
 
 

数组切片总和

尝试此示例

View MATLAB Command

使用向量维度参数来操作数组的特定切片。

创建所有元素为 1 的三维数组。

A = ones(4,3,2);

要对 A 的每个页面中的所有元素求和,请使用向量维度参数指定要求和的维度(行和列)。由于两个页面均为 4×3 矩阵,因此每页的总和为 12。

S1 = sum(A,[1 2])
S1 =
S1(:,:,1) = 12 S1(:,:,2) = 12

如果沿第一个维度对 A 进行切片,则可以对得到的 4 个页面的元素求和,每个页面为 3×2 矩阵。

S2 = sum(A,[2 3])
S2 = 4×1

     6
6
6
6

沿第二个维度切片,每个页面总和超过 4×2 矩阵。

S3 = sum(A,[1 3])
S3 = 1×3

     8     8     8

从 R2018b 开始,要对数组的所有维度求和,可以在向量维度参数中指定每个维度,或使用 'all' 选项。

S4 = sum(A,[1 2 3])
S4 = 24
Sall = sum(A,'all')
Sall = 24
 
 

三维数组的总和

尝试此示例

View MATLAB Command

创建一个由 1 值组成的 4×2×3 数组,并计算沿第三个维度的总和。

A = ones(4,2,3);
S = sum(A,3)
S = 4×2

     3     3
3 3
3 3
3 3
 
 

32 位整数之和

尝试此示例

View MATLAB Command

创建一个由 32 位整数组成的向量,并通过将输出类型指定为 native 来计算其元素的 int32 总和。

A = int32(1:10);
S = sum(A,'native')
S = int32
55
 
 

总和,不包括 NaN

尝试此示例

View MATLAB Command

创建一个向量并计算其总和,不包括 NaN 值。

A = [1.77 -0.005 3.98 -2.95 NaN 0.34 NaN 0.19];
S = sum(A,'omitnan')
S = 3.3250

如果您不指定 'omitnan',则 sum(A) 会返回 NaN

 
 

输入参数

全部折叠

A - 输入数组
向量 | 矩阵 | 多维数组

输入数组,指定为向量、矩阵或多维数组。

  • 如果 A 是标量,则 sum(A) 返回 A

  • 如果 A 是 0×0 空矩阵,则 sum(A) 返回 0

数据类型: single | double | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64 | logical | char | duration
复数支持:

dim - 沿其运算的维度
正整数标量

沿其运算的维度,指定为正整数标量。如果未指定值,则默认值是大小不等于 1 的第一个数组维度。

维度 dim 表示长度减至 1 的维度。size(S,dim)1,而所有其他维度的大小保持不变。

以一个二维输入数组 A 为例:

  • sum(A,1)A 的列中的连续元素进行求和并返回一个包含每列之和的行向量。

  • sum(A,2)A 的行中的连续元素进行求和并返回一个包含每行之和的列向量。

dim 大于 ndims(A) 或者 size(A,dim)1 时,sum 返回 A

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

vecdim - 维度向量
正整数向量

维度向量,指定为正整数向量。每个元素代表输入数组的一个维度。指定的操作维度的输出长度为 1,而其他保持不变。

以 2×3×3 输入数组 A 为例。然后 sum(A,[1 2]) 返回 1×1×3 数组,其元素是 A 的每个页面的总和。

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

outtype - 输出数据类型
'default' (默认) | 'double' | 'native'

输出数据类型,指定为 'default''double''native'。这些选项还指定执行运算采用的数据类型。

outtype 输出数据类型
'default' double,但当输入数据类型为 singleduration 时,输出类型则为 'native'
'double' double,但当数据类型为 duration 时不支持 'double' 类型
'native' 与输入相同的数据类型,但当输入数据类型为 char 时不支持 'native'

数据类型: char

nanflag - NaN 条件
includenan’ (默认) | ‘omitnan

NaN 条件,指定为下列值之一:

  • 'includenan' - 计算总和时包括 NaN 值,生成 NaN

  • 'omitnan' - 忽略输入中的所有 NaN 值。

数据类型: char

扩展功能

tall 数组
对行数太多而无法放入内存的数组进行计算。

此函数完全支持 tall 数组。有关详细信息,请参阅 tall 数组

C/C++ 代码生成
使用 MATLAB Coder 生成 C 代码和 C++ 代码。

用法说明和限制:

GPU 数组
通过使用 Parallel Computing Toolbox 在图形处理单元 (GPU) 上运行来加快代码执行。

用法说明和限制:

  • 未定义 sum 运算中的加法顺序。因此,对 GPU 数组的 sum 运算和对相应 MATLAB 数值数组的 sum 运算所返回的答案可能不完全相同。当 A 是有符号整数类型且其乘积在本机累积时,差异可能相当大。

有关详细信息,请参阅Run MATLAB Functions on a GPU (Parallel Computing Toolbox)。

分布式数组
使用 Parallel Computing Toolbox 在群集的组合内存中对大型数组进行分区。

用法说明和限制:

  • 未定义 sum 运算中的加法顺序。因此,对分布式数组执行 sum 运算和对相应 MATLAB 数值数组执行 sum 运算所返回的答案可能不完全相同。当 A 是有符号整数类型且其乘积在本机累积时,差异可能相当大。

有关详细信息,请参阅Run MATLAB Functions with Distributed Arrays (Parallel Computing Toolbox)。

另请参阅

matlab中sum的更多相关文章

  1. Matlab中rand('state',sum(clock))解析

    一.问题来源 来自于一份PSO代码,PSO中需要初始化粒子位置和速度. 二.问题探究 众所周知,Matlab中的rand()函数产生的是伪随机数,但一般用来也可以接受.但是,如果我们知道伪随机数的初始 ...

  2. MATLAB 中NORM运用

    格式:n=norm(A,p)功能:norm函数可计算几种不同类型的矩阵范数,根据p的不同可得到不同的范数 以下是Matlab中help norm 的解释 NORM   Matrix or vector ...

  3. MATLAB中白噪声的WGN和AWGN函数的使用

    MATLAB中白噪声的WGN和AWGN函数的使用如下: MATLAB中产生高斯白噪声非常方便,可以直接应用两个函数,一个是WGN,另一个是AWGN.WGN用于产生高斯白噪声,AWGN则用于在某一 信号 ...

  4. Matlab中如何将(自定义)函数作为参数传递给另一个函数

    假如我们编写了一个积分通用程序,想使它更具有通用性,那么可以把被积函数也作为一个参数.在c/c++中,可以使用函数指针来实现上边的功能,在matlab中如何实现呢?使用函数句柄--这时类似于函数指针的 ...

  5. Matlab中的数据类型

    Matlab中有15种基本数据类型,主要是整型.浮点.逻辑.字符.日期和时间.结构数组.单元格数组以及函数句柄等.         1.整型:(int8:uint8:int16:uint16:int3 ...

  6. [转] Matlab中给信号加高斯白噪声的方法

    MATLAB中产生高斯白噪声非常方便,可以直接应用两个函数,一个是WGN,另一个是AWGN.WGN用于产生高斯白噪声,AWGN则用于在某一信号中加入高斯白噪声. 1. WGN:产生高斯白噪声 y = ...

  7. 关于MATLAB中的tic toc的问题

    关于MATLAB中的tic toc的问题 其一) MATLAB实际单位时间计时函数的具体应用,在编写程序时,经常需要获知代码的执行实际时间,这就需要在程序中用到计时函数,matlab中提供了以下三种方 ...

  8. matlab中norm与svd函数用法

    格式:n=norm(A,p) 功能:norm函数可计算几种不同类型的矩阵范数,根据p的不同可得到不同的范数 以下是Matlab中help norm 的解释: NORM Matrix or vector ...

  9. MATLAB中“fitgmdist”的用法及其GMM聚类算法

    MATLAB中“fitgmdist”的用法及其GMM聚类算法 作者:凯鲁嘎吉 - 博客园http://www.cnblogs.com/kailugaji/ 高斯混合模型的基本原理:聚类——GMM,MA ...

随机推荐

  1. 万字长文,一篇文章带你入门Python

    注释 很多人学习python,不知道从何学起.很多人学习python,掌握了基本语法过后,不知道在哪里寻找案例上手.很多已经做案例的人,却不知道如何去学习更加高深的知识.那么针对这三类人,我给大家提供 ...

  2. 《神经网络的梯度推导与代码验证》之CNN前向和反向传播过程的代码验证

    在<神经网络的梯度推导与代码验证>之CNN的前向传播和反向梯度推导 中,我们学习了CNN的前向传播和反向梯度求导,但知识仍停留在纸面.本篇章将基于深度学习框架tensorflow验证我们所 ...

  3. 【HttpRunner v3.x】笔记—8.用例引用、变量传递

    看到这里,对于httprunner已经有了一个大概的了解,现在想对于一些比较重要或者常用的功能,进行一些实践操作. 毕竟那谁说过,"纸上得来终觉浅,绝知此事要躬行." 上一篇提到了 ...

  4. FZU - 2037 -Maximum Value Problem(规律题)

    Let’s start with a very classical problem. Given an array a[1…n] of positive numbers, if the value o ...

  5. Codeforces 1337D Xenia and Colorful Gems

    题意 给你3个数组\(a, b\)和\(c\),最小化\((x-y)^2+(y-z)^2+(z-x)^2\),其中\(x \in a, y \in b, z \in c\). 解题思路 这题其实第一眼 ...

  6. C015:十进制转8进制

    程序: #include "stdafx.h" #include <string.h> int _tmain(int argc, _TCHAR* argv[]) { i ...

  7. Mybatis源码如何阅读,教你一招!!!

    前言 前一篇文章简单的介绍了Mybatis的六个重要组件,这六剑客占据了Mybatis的半壁江山,和六剑客搞了基友,那么Mybatis就是囊中之物了.对六剑客感兴趣的朋友,可以看看这篇文章:Mybat ...

  8. VMware参数disk.EnableUUID生效扫描不出来UUID

    问题描述:搭建RAC中的共享磁盘,在一个节点上部署磁盘,另一个节点加入共享磁盘,使用扫描UUID的方法,但是莫名其妙一直扫描不出来UUID,使用了各种各样的方法,一个星期时间接近崩溃,又搞了一下午的测 ...

  9. time模块:时间戳和格式化好的时间表示方法及互相转换方法

    1.导入time模块   import time 2.获取当前时间的时间戳   time.time() 3.获取当前格式化好的时间   time.strftime(想要获取的格式) 4.时间戳和格式化 ...

  10. python中的一些内置函数

    1.布尔类型 2.求和sum 3.取全局变量和局部变量 4.ascii码和字符集 chr().ord() 5.看某个功能下有哪些方法 help(x).dir(x) 6.exec执行python代码 7 ...