Tensor(张量)

1、Tensor,又名张量,从工程角度来说,可简单地认为它就是一个数组,且支持高效的科学计算。它可以是一个数(标量)、一维数组(向量)、二维数组(矩阵)或更高维的数组(高阶数组),torch里的Tensor支持GPU加速。

基本操作

1、从接口的角度讲,对tensor的操作可分为两类:
(1)torch.function,如torch.save等
(2)tensor.function,如tensor.view等
2、从存储的角度讲,对tensor的操作又可分为两类:
(1)不会修改自身的数据,如a.add(b),加法的结果会返回一个新的tensor
(2)会修改自身的数据,如a.add_(b),加法的结果仍存储在a中,a被修改了
函数名以_结尾的都是inplace方式,即会修改调用者自己的数据,在实际应用中需要加以区分。
  1. #_Author_:Monkey
  2. #!/usr/bin/env python
  3. #-*- coding:utf-8 -*-
  4. import torch as t
  5. # from __future__ import print_function
  6. a = t.Tensor(2,3)       #指定Tensor的形状,a的数值取决于内存空间的状态
  7. print(a)
  8. '''''tensor([[2.1469e+33, 5.9555e-43, 2.1479e+33],
  9. [5.9555e-43, 6.3273e+30, 5.9555e-43]])'''
  10. b = t.Tensor([ [1,2,3],[4,5,6] ])       #用list的数据创建Tensor
  11. print(b)
  12. '''''tensor([[1., 2., 3.],
  13. [4., 5., 6.]])'''
  14. c = b.tolist()      #Tensor转list
  15. print(c)
  16. '''''[[1.0, 2.0, 3.0], [4.0, 5.0, 6.0]]'''
  17. #torch.size()返回torch.Size的子类,但其使用方式与tuple稍有区别
  18. b_size = b.size()
  19. print(b_size)
  20. '''''torch.Size([2, 3])'''
  21. d = b.numel()
  22. print(d)
  23. '''''6'''
  24. #创建一个和b形状一样的tensor
  25. e = t.Tensor(b_size)
  26. f = t.Tensor((2,3))
  27. print(e)
  28. print(f)
  29. '''''tensor([[2.6492e+21, 4.5908e-41, 0.0000e+00],
  30. [0.0000e+00, 1.4013e-45, 2.9775e-41]])
  31. tensor([2., 3.])'''
  32. print(e.shape)
  33. '''''torch.Size([2, 3])'''
  34. print(t.ones(2,3))
  35. '''''tensor([[1., 1., 1.],
  36. [1., 1., 1.]])'''
  37. print(t.zeros(2,3))
  38. '''''tensor([[0., 0., 0.],
  39. [0., 0., 0.]])'''
  40. print(t.arange(1,6,2))
  41. '''''tensor([1, 3, 5])'''
  42. print(t.linspace(1,10,3))
  43. '''''tensor([ 1.0000,  5.5000, 10.0000])'''
  44. print(t.randn(2,3))
  45. '''''tensor([[-0.3437, -0.3981, -0.3250],
  46. [ 2.6717, -0.7511, -0.5858]])'''
  47. print(t.randperm(5))        #长度为5的随机排序
  48. '''''tensor([4, 0, 3, 2, 1])'''
  49. print(t.eye(2,3))           #对角线为1,不要求行列数一致
  50. '''''tensor([[1., 0., 0.],
  51. [0., 1., 0.]])'''

Tensor基本操作的更多相关文章

  1. pytorch入坑一 | Tensor及其基本操作

    由于之前的草稿都没了,现在只有重写…. 我好痛苦 本章只是对pytorch的常规操作进行一个总结,大家看过有脑子里有印象就好,知道有这么个东西,需要的时候可以再去详细的看,另外也还是需要在实战中多运用 ...

  2. Pytorch-Tensor基本操作

    (此文为个人学习pytorch时的笔记,便于之后的查询) Tensor基本操作 创建tensor: ​ 1.numpy向量转tensor: a=np.array([2,2,2]) b=torch.fr ...

  3. pytorch笔记

    Tensor slice Tensor的indices操作 以[2,3]矩阵为例,slice后可以得到任意shape的矩阵,并不是说一定会小于2行3列. import torch truths=tor ...

  4. 解释张量及TF的一些API

    张量的定义 张量(Tensor)理论是数学的一个分支学科,在力学中有重要应用.张量这一术语起源于力学,它最初是用来表示弹性介质中各点应力状态的,后来张量理论发展成为力学和物理学的一个有力的数学工具.张 ...

  5. 深度学习原理与框架-Tensorflow基本操作-变量常用操作 1.tf.random_normal(生成正态分布随机数) 2.tf.random_shuffle(进行洗牌操作) 3. tf.assign(赋值操作) 4.tf.convert_to_tensor(转换为tensor类型) 5.tf.add(相加操作) tf.divide(相乘操作) 6.tf.placeholder(输入数据占位

    1. 使用tf.random_normal([2, 3], mean=-1, stddev=4) 创建一个正态分布的随机数 参数说明:[2, 3]表示随机数的维度,mean表示平均值,stddev表示 ...

  6. 深度学习框架Tensor张量的操作使用

    - 重点掌握基本张量使用及与numpy的区别 - 掌握张量维度操作(拼接.维度扩展.压缩.转置.重复……) numpy基本操作: numpy学习4:NumPy基本操作 NumPy 教程 1. Tens ...

  7. TensorFlow、numpy、matplotlib、基本操作

    一.常量的定义 import tensorflow as tf #类比 语法 api 原理 #基础数据类型 运算符 流程 字典 数组 data1 = tf.constant(2,dtype=tf.in ...

  8. Key/Value之王Memcached初探:二、Memcached在.Net中的基本操作

    一.Memcached ClientLib For .Net 首先,不得不说,许多语言都实现了连接Memcached的客户端,其中以Perl.PHP为主. 仅仅memcached网站上列出的语言就有: ...

  9. Android Notification 详解(一)——基本操作

    Android Notification 详解(一)--基本操作 版权声明:本文为博主原创文章,未经博主允许不得转载. 微博:厉圣杰 源码:AndroidDemo/Notification 文中如有纰 ...

随机推荐

  1. tomcat设置为开机自启动

    第一步:设置环境变量(在java环境变量配置完成的情况下) 计算机右键——>属性——>高级系统设置——>环境变量——>在用户变量中心新建CATALINA_HOME变量 编辑pa ...

  2. selenium + python自动化测试(一)

    本篇随笔为散集.不多逼逼直接干 step 1:使用webdriver调用浏览器,webdriver支持的浏览器为Firefox(),IE(),Chrome(),不同的浏览器需要安装不同的驱动. 本文使 ...

  3. hibernate原生sql获取list<T>异常解决

    /** * <p>Title: getbigestMinIntegral</p> * <p>Description: 获取最大的MinIntegral(原则上即最高 ...

  4. python&django 实现页面中关联查询小功能(中级篇)

    目的 组合搜索实现如下图功能 知识点 1.使用自定义标签模板(templatetags) 实现 models.py 和 views.py和初级篇一样 重点如下:在app01目录下创建templatet ...

  5. python3数学函数

    数 学 函 数 abs(x) 返回数字的绝对值,如abs(-10) 返回 10 ceil(x) 返回数字的上入整数,如math.ceil(4.1) 返回 5 cmp(x, y) 如果 x < y ...

  6. Java基础14-缓冲区字节流;File类

    作业解析 阐述BufferedReader和BufferedWriter的工作原理, 是否缓冲区读写器的性能恒大于非缓冲区读写器的性能,为什么,请举例说明? 答: BufferedReader对Rea ...

  7. hibernate 一对多 取多方数据重复问题,FetchMode.JOIN、FetchMode.SELECT、FetchMode.SUBSELECT区别

    问题描述:稿件附件表数据时出现多条重复数据. 介绍: 表:稿件实体Manuscripts (数据库表MANUSCRIPTS),稿件附件实体ManuscriptsAtt(表MANUSCRIPTS_ATT ...

  8. 关于mvc中传递匿名对象,view中无法解析

    最近做项目用到MVC,发现用linq查询得到的数据是匿名类型对象,通过模型绑定.或者ViewBag.ViewData进行数据传递后,View解析报错:“object 未包含xx的定义”: 没找到好的解 ...

  9. Python深度学习(Deep Learning with Python) 中文版+英文版+源代码

    Keras作者.谷歌大脑François Chollet最新撰写的深度学习Python教程实战书籍(2017年12月出版)介绍深入学习使用Python语言和强大Keras库,详实新颖.PDF高清中文版 ...

  10. 文本超出显示省略号/数字英文字母折行有关css 属性/显示两行,第二行省略号显示css方法

    文本超出显示省略号: 定容器宽度 overflow: hidden; text-overflow: ellipsis; 文本超出显示省略号 white-space:nowrap;  强制文本不换行 折 ...