- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章浅谈tensorflow使用张量时的一些注意点tf.concat,tf.reshape,tf.stack由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
有一段时间没用tensorflow了,现在跑实验还是存在一些坑了,主要是关于张量计算的问题。tensorflow升级1.0版本后与以前的版本并不兼容,可能出现各种奇奇怪怪的问题.
1 tf.concat函数 。
tensorflow1.0以前函数用法:tf.concat(concat_dim, values, name='concat'),第一个参数为连接的维度,可以将几个向量按指定维度连接起来.
如:
1
2
3
4
5
6
|
t1
=
[[
1
,
2
,
3
], [
4
,
5
,
6
]]
t2
=
[[
7
,
8
,
9
], [
10
,
11
,
12
]]
#按照第0维连接
tf.concat(
0
, [t1, t2])
=
=
> [[
1
,
2
,
3
], [
4
,
5
,
6
], [
7
,
8
,
9
], [
10
,
11
,
12
]]
#按照第1维连接
tf.concat(
1
, [t1, t2])
=
=
> [[
1
,
2
,
3
,
7
,
8
,
9
], [
4
,
5
,
6
,
10
,
11
,
12
]]
|
tf.concat的作用主要是将向量按指定维连起来,其余维度不变;而1.0版本以后,函数的用法变成:
1
2
3
4
5
6
|
t1
=
[[
1
,
2
,
3
], [
4
,
5
,
6
]]
t2
=
[[
7
,
8
,
9
], [
10
,
11
,
12
]]
#按照第0维连接
tf.concat( [t1, t2],
0
)
=
=
> [[
1
,
2
,
3
], [
4
,
5
,
6
], [
7
,
8
,
9
], [
10
,
11
,
12
]]
#按照第1维连接
tf.concat([t1, t2],
1
)
=
=
> [[
1
,
2
,
3
,
7
,
8
,
9
], [
4
,
5
,
6
,
10
,
11
,
12
]]
|
位置变了,需要注意.
2 tf.stack函数 。
用法:stack(values, axis=0, name=”stack”)
“”“Stacks a list of rank-R tensors into one rank-(R+1) tensor. 。
1
2
3
4
5
6
|
x
=
tf.constant([
1
,
4
])
y
=
tf.constant([
2
,
5
])
z
=
tf.constant([
3
,
6
])
tf.stack([x,y,z])
=
=
> [[
1
,
4
],[
2
,
5
],[
3
,
6
]]
tf.stack([x,y,z],axis
=
0
)
=
=
> [[
1
,
4
],[
2
,
5
],[
3
,
6
]]
tf.stack([x,y,z],axis
=
1
)
=
=
> [[
1
,
2
,
3
], [
4
,
5
,
6
]]
|
tf.stack将一组R维张量变为R+1维张量。注意:tf.pack已经变成了tf.stack 。
3.tf.reshape 。
用法:reshape(tensor, shape, name=None):主要通过改变张量形状,可以从高维变低维,也可以从低维变高维; 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
|
a
=
tf.Variable(initial_value
=
[[
1
,
2
,
3
],[
4
,
5
,
6
]])
=
=
> shape:[
2
,
3
]
b
=
tf.Variable(initial_value
=
[[[
1
,
2
,
3
],[
4
,
5
,
6
]],[[
7
,
8
,
9
],[
1
,
0
,
2
]]])
=
=
> shape:[
2
,
2
,
3
]
a_1
=
tf.reshape(a,[
2
,
1
,
1
,
3
])
=
=
> [[[[
1
,
2
,
3
]]],[[[
4
,
5
,
6
]]]]
a_2
=
tf.reshape(a,[
2
,
1
,
3
])
=
=
> [[[
1
,
2
,
3
]],[[
4
,
5
,
6
]]]
b_1
=
tf.reshape(b,[
2
,
2
,
1
,
3
])
=
=
> [[[[
1
,
2
,
3
]],[[
4
,
5
,
6
]]],[[[
7
,
8
,
9
]],[[
1
,
0
,
2
]]]]
new_1
=
tf.concat([b_1,a_1],
1
)
new_2
=
tf.reshape(tf.concat([b,a_2],
1
),[
2
,
3
,
1
,
3
])
"""
new_1:
[[[[
1
2
3
]]
[[
4
5
6
]]
[[
1
2
3
]]]
[[[
7
8
9
]]
[[
1
0
2
]]
[[
4
5
6
]]]]
new_2;
[[[[
1
2
3
]]
[[
4
5
6
]]
[[
1
2
3
]]]
[[[
7
8
9
]]
[[
1
0
2
]]
[[
4
5
6
]]]]
|
补充知识:tensorflow中的reshape(tensor,[1,-1])和reshape(tensor,[-1,1]) 。
和python 中的reshape用法应该一样 。
1
2
3
4
5
6
|
import
tensorflow as tf
a
=
[[
1
,
2
],[
3
,
4
],[
5
,
6
]]
tf.reshape(a,[
-
1
,
1
])
Out[
13
]: <tf.Tensor
'Reshape_4:0'
shape
=
(
6
,
1
) dtype
=
int32>
tf.reshape(tf.reshape(a,[
-
1
,
1
]),[
1
,
-
1
])
Out[
14
]: <tf.Tensor
'Reshape_6:0'
shape
=
(
1
,
6
) dtype
=
int32>
|
tf.reshape(tensor,[-1,1])将张量变为一维列向量 。
tf.reshape(tensor,[1,-1])将张量变为一维行向量 。
以上这篇浅谈tensorflow使用张量时的一些注意点tf.concat,tf.reshape,tf.stack就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我.
原文链接:https://blog.csdn.net/a18852867035/article/details/79048684 。
最后此篇关于浅谈tensorflow使用张量时的一些注意点tf.concat,tf.reshape,tf.stack的文章就讲到这里了,如果你想了解更多关于浅谈tensorflow使用张量时的一些注意点tf.concat,tf.reshape,tf.stack的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
在编写代码时,当我编写 struct *Stack stack 时,代码无法工作,而当我像 struct Stack* stack 那样编写代码时,代码可以工作有人告诉我这两个代码之间的区别吗? 最佳
我的教授要我绘制堆栈吗?他想让我付诸行动吗?我觉得自己很愚蠢,但这不像任何人告诉我的那样!感谢您的帮助。 哇,你们真快。已经谢谢你了。完整的问题是:考虑两个堆栈,每个堆栈的大小为 n(即,每个堆栈最多
是new Stack[N]相当于new Stack[N]对于通用数据类型 Stack ? 编辑:虽然我知道最好避免混合泛型类型和数组,并且存在更强大的解决方案,但我的查询仍然存在:被广泛认可的教科书,
我正在尝试使用堆栈的 printf() 打印 stack.top() 的返回值,但它给出的格式不匹配。代码如下: int main(){ stack cards; char *ch1
我正在尝试做一个 dapp 项目。 我有一个堆栈太深的错误,但我不知道如何解决这个问题。 CompilerError: Stack too deep, try removing local varia
在哪里stack haddock (或 stack build --haddock )放置它生成的文档? 最佳答案 这取决于为“属于”生成黑线鳕的包的位置。 “本地”包的 Haddocks 是堆栈项目
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
基本上,我有 2 个文件(.adb 和 .ads)。我对 Ada 以及如何编译 2 个文件完全陌生。该程序是一个基本的堆栈实现。编译 .adb 文件时出现此编译错误。 $ gcc -c test_ad
关闭。这个问题需要更多focused .它目前不接受答案。 想改善这个问题吗?更新问题,使其仅关注一个问题 editing this post . 5年前关闭。 Improve this questi
您好,我正在尝试在微服务架构中使用 ELK 堆栈,其中有许多服务分布在许多服务器上。 现在我已经配置了 Kibana 和 ElasticSearch。现在我的疑问是我必须在哪里安装 Logstash。
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 9
我正在学习 Haskell,但遇到了我没想到的异常“堆栈溢出”。 代码相当简单: type Reals = Double prod :: Reals -> Reals -> Reals prod a
在我的 PC(最新的 JDK 和编译器版本)上,我的程序运行得非常顺利。但在我教授的计算机上,她说她遇到了两个错误 1) Stack myStack= new Stack() 类型的非法开始 2) 非
当我尝试在调用跟踪后执行 ./stack.sh 时,我收到以下错误: `[Call Trace] ./stack.sh:217:source /home/work/devstack/stackrc
1 上下文 我参与了一个涉及大量 C 位和 FFI 的 Haskell 项目。所以我发现自己经常运行和重新运行命令,比如 $ stack build $ stack build --force-dir
关于 SO 上的堆栈的问题,终于!我的一生都让我走到了这一步。 所以我需要将我制作的一些相当大的自定义数据结构合并到一个堆栈中。我决定编写一个仅包含一个整数值的最小堆栈结构。这里是 - MODULE
我只是想知道为什么在括号之间嵌入表达式时会得到两个不同的成员列表,例如gl-stack。看起来,如果没有括号,表达式就会被完全求值,并且结果会立即传递到下一个管道组件。但通过括号,集合中的单个对象将被
是否可以保存Stack>在onSaveInstanceState . 是否可以通过另一种方式保存某些特定数据来管理 Activity 状态? 最佳答案 您无法将 View 保存到 bundle 中。无
这个问题已经有答案了: Why don't Java Generics support primitive types? (5 个回答) 已关闭 9 年前。 为什么我不能使用Stack ? 除了拳击之
基于数组的实现级别 #include "stack.h" void creat_stack(Stack *s) { s->Top = 0; } int isFull(Stack s) {
我是一名优秀的程序员,十分优秀!