张量的修改与运算|学习笔记

简介: 快速学习张量的修改与运算

开发者学堂课程【深度学习框架 TensorFlow 入门张量的修改与运算学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址https://developer.aliyun.com/learning/course/773/detail/13543


张量的修改与运算


内容简介

一、ndarray 属性的修改

二、形状变化

三、张量的数学运算


一、ndarray 属性的修改

(1)类型的修改

ndarray.astype(type)

ndarray.tostring()  

代码如下:

def tensor_ demo():

……

#张量的演示

……

; return:

tensor1 = tf. constant(4.0)

tensor2 = tf. constant((1, 2, 3, 4])

linear_ squares = tf. constant([[4], [9], [16], [25]], dtype=tf. int32)

print ("tensor1:\n", tensor1)

print ("tensor2:\n", tensor2)

print ("linear_ squares_before:\n", linear_ squares )

#张量类型的修改

l_ cast = tf. cast(linear_ squares, dtype=tf. float32)

print ("linear_ squares_after:\n", linear_ squares )

print("l_cast:\n", l_cast)

return None

(2)形状的修改

ndarray.reshape(shape)

加上-1表示自动计算形状

ndarray.resize(shape)

reshape 与 resize 的区别,reshape 会返回一个新的数组,而resize 是就地修改原来的 ndarray。


二、形状变化

TensorFlow 的张量具有两种形状变换,动态形状和静态形状

tf.reshape

tf.set_shape

关于动态形状和静态形状必须符合以下规则

(1)静态形状

只有在形状完全没有固定下来的情况才能更新静态形状

tensor.set_shape(shape)

转换静态形状的时候,1-D到1-D, 2-D到2-D, 不能跨阶数改变形状

对于已经固定的张量的静态形状的张量,不能再次设置静态形状

代码案例:

#更新/改变静态形状

#定义占位符

#形状没有完全固定下来的静态形状

a_p = tf.placeholder(dtype=tf. float32, shape= (None, None])

b_P = tf.placeholder(dtype=tf. float32, shape= (None, 10])

c_p = tf.placeholder(dtype=tf. float32, shape=[3, 2])

print("a_ p:\n", a_p)

print("b_ p:\n", b_p)

print("c_ p:\n", c_p)

#更新形状未确定的部分

a_p.set_shape([2,3])

b_p.set_shape([2,10])

print(“a_p:\n”,a_p)

print(“b_p:\n”,b_p)

return None

(2)动态形状

通过 tf.reshape(tensor,shape)改变动态形状

不会改变原始的 tensor,返回新的改变形状后的 tensor  

tf.reshape() 动态创建新张量时,张量的元素个数必须匹配

代码案例:

a_p=tf.placeholder(dtype=tf.float32,shape=[None,None])

……

print("a_ p:\n", a_p)

……

# 动态形状修改

a_p_reshape = tf. reshape(a_p, shape=(2, 3, 1])

print("a_p:\n", a_p)

print("a_p_reshape:\n", a_p_reshape)

return None


三、张量的数学运算

算术运算符

基本数学函数

矩阵运算

reduce 操作

序列索引操作

详细请参考:

https://www.tensorflow.org/versions/r1.8/api guides/python/math ops

这些 API 使用,我们在使用的时候介绍,具体参考文档

相关文章
|
机器学习/深度学习 搜索推荐 数据挖掘
【Pytorch神经网络理论篇】 25 基于谱域图神经网络GNN:基础知识+GNN功能+矩阵基础+图卷积神经网络+拉普拉斯矩阵
图神经网络(Graph Neural Network,GNN)是一类能够从图结构数据中学习特征规律的神经网络,是解决图结构数据(非欧氏空间数据)机器学习问题的最重要的技术之一。
1341 0
|
存储 机器学习/深度学习 算法
图神经网络学习笔记-01基础(一)
图神经网络学习笔记-01基础(一)
475 0
图神经网络学习笔记-01基础(一)
|
安全 调度 Windows
面试总结-进程、线程与多线程
线程、进程和多线程是面试过程中很容易遇到的问题,去年百度三面的时候就遇到这个问题,当时百度hr问到:线程和进程的区别是什么?你写过多进程或者多线程的程序吗?在你看来多线程和多进程程序那种程序比较难写? 第一个问题很常规,但是要完全答对却不是那么容易,现在想来,第二个问题和第三个问题实际是一个问题,因为第三个问题是验证第二个问题是否说实话的最好的方式。
1919 0
|
4天前
|
人工智能 运维 安全
|
2天前
|
人工智能 异构计算
敬请锁定《C位面对面》,洞察通用计算如何在AI时代持续赋能企业创新,助力业务发展!
敬请锁定《C位面对面》,洞察通用计算如何在AI时代持续赋能企业创新,助力业务发展!
|
10天前
|
人工智能 JavaScript 测试技术
Qwen3-Coder入门教程|10分钟搞定安装配置
Qwen3-Coder 挑战赛简介:无论你是编程小白还是办公达人,都能通过本教程快速上手 Qwen-Code CLI,利用 AI 轻松实现代码编写、文档处理等任务。内容涵盖 API 配置、CLI 安装及多种实用案例,助你提升效率,体验智能编码的乐趣。
833 109
|
4天前
|
机器学习/深度学习 人工智能 自然语言处理
B站开源IndexTTS2,用极致表现力颠覆听觉体验
在语音合成技术不断演进的背景下,早期版本的IndexTTS虽然在多场景应用中展现出良好的表现,但在情感表达的细腻度与时长控制的精准性方面仍存在提升空间。为了解决这些问题,并进一步推动零样本语音合成在实际场景中的落地能力,B站语音团队对模型架构与训练策略进行了深度优化,推出了全新一代语音合成模型——IndexTTS2 。
433 11
|
3天前
|
人工智能 测试技术 API
智能体(AI Agent)搭建全攻略:从概念到实践的终极指南
在人工智能浪潮中,智能体(AI Agent)正成为变革性技术。它们具备自主决策、环境感知、任务执行等能力,广泛应用于日常任务与商业流程。本文详解智能体概念、架构及七步搭建指南,助你打造专属智能体,迎接智能自动化新时代。