Mindspore 初学教程 - 3. Tensor 张量

张量(Tensor)是一个可用来表示在一些矢量、标量和其他张量之间的线性关系的多线性函数,这些线性关系的基本例子有内积、外积、线性映射以及笛卡儿积。其坐标在  n n n 维空间内,有  n r n^{r} nr 个分量的一种量,其中每个分量都是坐标的函数,而在坐标变换时,这些分量也依照某些规则作线性变换。 r r r 称为该张量的秩或阶(与矩阵的秩和阶均无关系)。

张量是一种特殊的数据结构,与数组和矩阵非常相似。张量(Tensor)是MindSpore 网络运算中的基本数据结构。

一、创建张量

张量的创建方式有多种,构造张量时,支持传入Tensorfloatintbooltuplelistnumpy.ndarray 类型。

  • 根据数据直接生成:可以根据基本数据类型创建张量,数据类型可以设置或者通过框架自动推断。
  • 从 NumPy 数组生成:可以从NumPy数组创建张量。
  • 使用 init 初始化器构造张量:使用init初始化器对张量进行初始化时,支持传入的参数有initshapedtype。通常来说 init 主要用于并行模式下的延后初始化,在正常情况下不建议使用init对参数进行初始化。
    • init: 支持传入initializer的子类。如 One() 和 Normal()。
    • shape: 支持传入 listtupleint
    • dtype: 支持传入mindspore.dtype。
  • 继承另一个张量的属性,形成新的张量
# 根据数据直接生成
def gen_tensor_base():data = [1, 0, 1, 0]x_data = Tensor(data)show_tensor_attr(x_data)# 从 NumPy 数组生成
def gen_tensor_numpy():data = [1, 0, 1, 0]np_array = np.array(data)x_np = Tensor(np_array)show_tensor_attr(x_np)# 使用 init 初始化器构造张量
def gen_tensor_init():tensor1 = mindspore.Tensor(shape=(2, 2), dtype=mindspore.float32, init=One())# Initialize a tensor from normal distributiontensor2 = mindspore.Tensor(shape=(2, 2), dtype=mindspore.float32, init=Normal())print("tensor1:")show_tensor_attr(tensor1)print("tensor2:")show_tensor_attr(tensor2)# 继承另一个张量的属性,形成新的张量
def gen_tensor_extend():data = [1, 0, 1, 0]x_data = Tensor(data)x_ones = ops.ones_like(x_data)print(f"Ones Tensor: \n {x_ones} \n")x_zeros = ops.zeros_like(x_data)print(f"Zeros Tensor: \n {x_zeros} \n")
![请添加图片描述](https://i-blog.csdnimg.cn/direct/347e9a5620314495a2dcb04577de97f6.png)

二、张量的属性

张量的属性包括形状、数据类型、转置张量、单个元素大小、占用字节数量、维数、元素个数和每一维步长。

  • 形状(shape):Tensor的 shape,是一个 tuple。
  • 数据类型(dtype):Tensor的 dtype,是 MindSpore 的一个数据类型。
  • 单个元素大小(itemsize): Tensor 中每一个元素占用字节数,是一个整数。
  • 占用字节数量(nbytes): Tensor 占用的总字节数,是一个整数。
  • 维数(ndim): Tensor的秩,也就是len(tensor.shape),是一个整数。
  • 元素个数(size): Tensor 中所有元素的个数,是一个整数。
  • 每一维步长(strides): Tensor 每一维所需要的字节数,是一个tuple。
def show_tensor_attr(tensor:Tensor):# tensor 的 形状tensor_shape = tensor.shape# tensor 的 数据类型tensor_dtype = tensor.dtype# tensor 单个元素占用的字节数tensor_itemsize = tensor.itemsize# tensor 占用的字节数tensor_nbytes = tensor.nbytes# tensor 的秩,不同于矩阵的秩,这里指的是 len(tensor.shape)tensor_ndim = tensor.ndim# tensor 的 元素的数量tensor_size = tensor.size# tensor 每一维所需要的字节数tensor_strides = tensor.stridesfor name, value in locals().items():print(f"{name}: {value}")print()

三、张量索引

Tensor 索引与 Numpy 索引类似,索引从 0 开始编制,负索引表示按倒序编制,冒号 :... 用于对数据进行切片。

def show_tensor_index():tensor = Tensor(np.array([[0, 1], [2, 3]]).astype(np.float32))print("First row: {}".format(tensor[0]))print("value of bottom right corner: {}".format(tensor[1, 1]))print("Last column: {}".format(tensor[:, -1]))print("First column: {}".format(tensor[..., 0]))

在这里插入图片描述

四、张量运算

张量之间有很多运算,包括算术、线性代数、矩阵处理(转置、标引、切片)、采样等,张量运算和NumPy的使用方式类似,下面介绍其中几种操作。

4.1 普通算术

普通算术运算有:加(+)、减(-)、乘(*)、除(/)、取模(%)、整除(//)。

def base_calculate():x = Tensor(np.array([1, 2, 3]), mindspore.float32)y = Tensor(np.array([4, 5, 6]), mindspore.float32)# 加output_add = x + y# 减output_sub = x - y# 乘output_mul = x * y# 除output_div = y / x# 求余output_mod = y % x# 地板除 output_floordiv = y // xprint("add:", output_add)print("sub:", output_sub)print("mul:", output_mul)print("div:", output_div)print("mod:", output_mod)print("floordiv:", output_floordiv)

在这里插入图片描述

4.2 张量拼接

4.2.1 concat 拼接

concat 将给定维度上的一系列张量连接起来。

def show_concat(axis=0):data1 = Tensor(np.array([[0, 1], [2, 3]]).astype(np.float32))data2 = Tensor(np.array([[4, 5], [6, 7]]).astype(np.float32))output = ops.concat((data1, data2), axis=axis)print(output)print(output.shape, output.dtype)

在这里插入图片描述

4.2.2 stack 拼接

stack 是从另一个维度上将两个张量合并起来。

def show_stack():data1 = Tensor(np.array([[0, 1], [2, 3]]).astype(np.float32))data2 = Tensor(np.array([[4, 5], [6, 7]]).astype(np.float32))output = ops.stack([data1, data2])print(output)print("shape:\n", output.shape)

在这里插入图片描述

五、Tensor与NumPy转换

Tensor 可以和 NumPy 进行互相转换。

5.1 Tensor转换为NumPy

与张量创建相同,使用 Tensor.asnumpy() 将 Tensor 变量转换为 NumPy 变量。

def tensor2numpy():t = Tensor([1., 1., 1., 1., 1.])print(f"t: {t}", type(t))n = t.asnumpy()print(f"n: {n}", type(n))

在这里插入图片描述

5.2 NumPy转换为Tensor

使用 Tensor() 将 NumPy 变量转换为 Tensor 变量。

def numpy2tensor():n = np.ones(5)t = Tensor.from_numpy(n)np.add(n, 1, out=n)print(f"n: {n}", type(n))print(f"t: {t}", type(t))

在这里插入图片描述
注意: numpy 的值改变,Tensor 的值也会同步改变

六、稀疏张量

稀疏张量是一种特殊张量,其中绝大部分元素的值为零。在某些应用场景中(比如推荐系统、分子动力学、图神经网络等),数据的特征是稀疏的,若使用普通张量表征这些数据会引入大量不必要的计算、存储和通讯开销。这时就可以使用稀疏张量来表征这些数据。

MindSpore现在已经支持最常用的 CSRCOO 两种稀疏数据格式。常用稀疏张量的表达形式是<indices:Tensor, values:Tensor, shape:Tensor>。其中,indices表示非零下标元素, values 表示非零元素的值,shape表示的是被压缩的稀疏张量的形状。在这个结构下,mindSpore 定义了 两种稀疏张量结构:CSRTensorCOOTensor (其中 RowTensor 在 1.7 版本后已经弃用)。

6.1 CSRTensor

CSR(Compressed Sparse Row)稀疏张量格式有着高效的存储与计算的优势。其中,非零元素的值存储在values中,非零元素的位置存储在indptr(行)和indices(列)中。各参数含义如下:

  • indptr: 一维整数张量, 表示稀疏数据每一行的非零元素在values中的起始位置和终止位置, 索引数据类型支持int16、int32、int64。
  • indices: 一维整数张量,表示稀疏张量非零元素在列中的位置, 与values长度相等,索引数据类型支持int16、int32、int64。
  • values: 一维张量,表示CSRTensor相对应的非零元素的值,与indices长度相等。
  • shape: 表示被压缩的稀疏张量的形状,数据类型为Tuple,目前仅支持二维CSRTensor

CSRTensor 的详细文档,请参考mindspore.CSRTensor。

def show_CSRTensor():indptr = Tensor([0, 2, 5, 6])indices = Tensor([0, 3, 1, 2, 4, 2])values = Tensor([1., 2., 3., 4., 5., 6.], dtype=mindspore.float32)shape = (3, 5)# Make a CSRTensorcsr_tensor = CSRTensor(indptr, indices, values, shape)print(csr_tensor.to_dense())print(csr_tensor.astype(mindspore.float64).dtype)

在这里插入图片描述
其中 indptr 为 [0, 2, 5, 6],表示 indices [0, 2)为第 0 行的数据,indices [2, 5) 为第 1 行的数据,indices [5, 6) 为第 2 行的数据。例如:稠密张量第 0 行非零元素所在的列位置由 indices 中的第 [0, 2) 个元素 ( 即[0, 3] ) 给出,实际值由 values 中的第 [0, 2) 个元素( 即 [1., 2.] ) 给出;第1行非零元素所在的列位置位置由 indices 中的第 [2, 5) 个元素( 即 [1, 2, 4] )给出,实际值由 values 中的第 [2, 5) 个元素 ( 即 [3., 4., 5.] ) 给出;第 2 行非零元素所在的列位置位置由 indices 中的第 [5, 6) 个元素( 即[2] )给出,实际值由 values 中的第 [5, 6) 个元素 ( 即[6.] ) 给出;

6.2 COOTensor

COO(Coordinate Format)稀疏张量格式用来表示某一张量在给定索引上非零元素的集合,若非零元素的个数为N,被压缩的张量的维数为ndims。各参数含义如下:

  • indices: 二维整数张量,每行代表非零元素下标。形状:[N, ndims], 索引数据类型支持int16、int32、int64。
  • values: 一维张量,表示相对应的非零元素的值。形状:[N]
  • shape: 表示被压缩的稀疏张量的形状,目前仅支持二维COOTensor

COOTensor的详细文档,请参考mindspore.COOTensor。

def show_COOTensor():indices = Tensor([[0, 1], [1, 2]], dtype=mindspore.int32)values = Tensor([1, 2], dtype=mindspore.float32)shape = (3, 4)# Make a COOTensorcoo_tensor = COOTensor(indices, values, shape)print(coo_tensor.to_dense())print(coo_tensor.astype(mindspore.float64).dtype)

在这里插入图片描述
其中索引(indices)指示了每一个非零元素的位置。对一个稠密 Tensor dense 来说,它对应的 COOTensor(indices, values, shape),满足 dense[indices[i]] = values[i] 。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/53254.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

学习日志8.30--防火墙NAT

目录 一、实验环境配置 二、配置防火墙静态NAT一对一 三、配置防火墙静态NAT多对多 四、配置防火墙NAT端口转换NAPT 五、防火墙smart-nat、easyip 六、防火墙三元组NAT 在学习过基于路由器的NAT网络地址转换&#xff0c;现在学习基于防火墙NAT的网络地址转换&#xff0c;…

纵向合并单元格——table

将list数据处理成tableDate格式&#xff0c;id重复的数据&#xff0c;只有第一项有num字段&#xff08;num是重复的个数&#xff09;渲染表格&#xff0c;纵向合并第1、2、6列&#xff0c;id相同的合并 <template><div><el-table:data"tableData":sp…

实体店同城商家引流的获客方法

实体店同城商家引流的获客方法 学会这3招&#xff0c;门店也能轻松获客&#xff01; #狂潮老师#电商#代运营#陪跑#门店获客#同城引流#爆款#引流#福利#达人#标签#短视频#直播#私域 推荐阅读&#xff1a; 百收网SEO引流脚本软件不断更新&#xff08;推广全集教程&#xff09;h…

4.sklearn-K近邻算法、模型选择与调优

文章目录 环境配置&#xff08;必看&#xff09;头文件引用1.sklearn转换器和估计器1.1 转换器 - 特征工程的父类1.2 估计器(sklearn机器学习算法的实现) 2.K-近邻算法2.1 简介&#xff1a;2.2 K-近邻算法API2.3 K-近邻算法代码2.4 运行结果2.5 K-近邻算法优缺点 3.模型选择与调…

数组与贪心算法——605、121、122、561、455、575(5简1中)

605. 种花问题&#xff08;简单&#xff09; 假设有一个很长的花坛&#xff0c;一部分地块种植了花&#xff0c;另一部分却没有。可是&#xff0c;花不能种植在相邻的地块上&#xff0c;它们会争夺水源&#xff0c;两者都会死去。 给你一个整数数组 flowerbed 表示花坛&#xf…

golang zap日志模块封装sentry

我们自己写个log日志包&#xff0c;把zap和sentry封装到一起。 下面直接贴上主要部分代码&#xff08;两个模块初始化部分的代码请自行查阅官方文档&#xff09;&#xff1a; logger.go package logimport ("github.com/getsentry/sentry-go""go.uber.org/zap…

Mapmost让你实现地图标注自由

最近在勤勤恳恳&#xff08;moyuhaushui&#xff09;搬砖之余&#xff0c;偶然间看到一个在线古籍图书馆&#xff0c;虽然对文言文阅读的心理障碍不亚于英文阅读理解&#xff0c;但网站中有很多历史图集还是引起了兴趣。比如这幅《水经注图》&#xff0c;顺藤摸瓜的瞧&#xff…

Java中对象拷贝的深度解析:从零拷贝到深拷贝的演进

前言 在Java编程世界中&#xff0c;对象的拷贝是一个基础而重要的操作。它涉及到内存管理、数据一致性以及程序的健壮性等多个方面。随着软件架构的复杂化和数据的多样化&#xff0c;对象拷贝的策略也从最初的简单赋值&#xff08;零拷贝&#xff09;发展到深拷贝&#xff0c;…

DataWorks数据质量监控方案

背景 日常的调度监控&#xff0c;可以查看实例任务的运行情况&#xff0c;对运行失败的实例进行告警&#xff0c;但是却无法对运行成功的实例进行数据质量的判断。而有些情况下&#xff0c;即使实例任务运行成功了&#xff0c;数据也仍然存在问题&#xff0c;这时候就需要对数…

揭秘Taboola原生广告:欧美流量变现联盟营销金牌策略

揭秘Taboola原生广告&#xff1a;欧美流量变现的金牌策略 在数字营销日益精进的今天&#xff0c;如何高效地将网站流量转化为实际收益成为了众多欧美网站主关注的焦点。Taboola&#xff0c;作为原生广告领域的佼佼者&#xff0c;凭借其独特的广告展示方式与强大的数据驱动能力…

上海晋名室外危化品暂存柜助力新能源行业发展

近日又有一个SAVEST室外危化品暂存柜项目成功验收交付使用。 用户在日常经营活动中涉及到气瓶和硅粉的室外安全暂存问题&#xff0c;4月下旬在网上看到上海晋名室外暂存柜系列很感兴趣&#xff0c;联系到了销售部钟经理&#xff0c;双方对晋名的室外暂存柜进行了高效的沟通&am…

无人机+应用综合实训室解决方案

随着无人机技术的飞速发展&#xff0c;其在航拍、农业、环境监测、物流运输等多个领域展现出巨大的应用潜力。为了满足职业院校及企业对无人机应用技术型人才的培养需求&#xff0c;唯众紧跟市场趋势&#xff0c;推出了全面且详尽的《无人机应用综合实训室解决方案》。本方案旨…

MACOS安装配置前端开发环境

官网下载安装Mac版本的谷歌浏览器以及VS code代码编辑器&#xff0c;还有在App Store中直接安装Xcode&#xff08;里面自带git&#xff09;&#xff1b; node.js版本管理器nvm的下载安装如下&#xff1a; 参考B站&#xff1a;https://www.bilibili.com/video/BV1M54y1N7fx/?sp…

【学习AI-相关路程-工具使用-自我学习-jetson模型训练-图片识别-使用模型检测图片-基础样例 (5)】

【学习AI-相关路程-工具使用-自我学习-jetson&模型训练-图片识别-使用模型检测图片-基础样例 &#xff08;5&#xff09;】 1 -前言2 -环境说明3 -先行了解&#xff08;1&#xff09;整理流程了解&#xff08;2&#xff09;了解模型-MobileNet1、MobileNetV2 的主要特性&am…

python源码 PBOCMaster MAC的计算函数及计算过程 2des

注意最后一步要用整个key加密 计算过程&#xff1a; MAC&#xff1a; PBOC-MAC DES算法 密钥 长度16(0x10)字节 57 75 20 4D 69 61 6F 6A 75 6E 40 47 26 44 43 11 初始向量 长度8(0x08)字节 00 00 00 00 00 00 00 00 数据 长度74(0x4A)字节 43 48 45 4E 48 41 4F 2D 50 43 7…

MSP430F149实现1.8寸TFT_LCD真彩屏显示

目录 一、功能实现 二、设备准备 三、接线表设计 四、代码实现 五、实现效果 六、代码链接 一、功能实现 实现1.8寸TFT_LCD真彩屏显示。显示数字、图片、字符串等。 二、设备准备 1.TFT_LCD真彩屏&#xff08;1.8寸&#xff09; 该真彩屏使用SPI通信。 2.MSP430F149开…

微服务CI/CD实践(五)Jenkins Docker 自动化构建部署Node服务

微服务CI/CD实践系列&#xff1a; 微服务CI/CD实践&#xff08;一&#xff09;环境准备及虚拟机创建 微服务CI/CD实践&#xff08;二&#xff09;服务器先决准备 微服务CI/CD实践&#xff08;三&#xff09;gitlab部署及nexus3部署 微服务CI/CD实践&#xff08;四&#xff09…

穿越机的应用行业!!!

1. 军事领域 侦察与目标搜索&#xff1a;穿越机能够快速穿越危险区域&#xff0c;执行侦察任务&#xff0c;实时获取战场信息&#xff0c;对敌方目标进行精确搜索和定位。其灵活性和机动性使其成为战场上的重要侦察工具。 目标摧毁&#xff1a;经过改装的穿越机可挂载火箭弹或…

华三防火墙第-安全策略02

一 安全策略的图解 安全策略是一种根据报文的属性信息对报文进行精细化转发控制的智能安全防护措施。它 融合了多维度精确报文识别、深度报文检测、安全动作执行、智能策略分析、应用风险调 优等多种安全防护功能,为网络的安全性提供全方位保障。 安全策略运行原理 安全策略对…

CSS实现文字环绕圆形展示

展示区域 代码区域 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>Document</title><s…