0
filename = 'SOMETHING';
eval(['load ' filename]);

eval(['load ' filename '_vid1'])
vid123=permute(vid,[2 1 3]);
size(vid)

eval(['load ' filename '_vid2'])
vid123(:,:,(size(vid123,3)+1):(size(vid123,3)+size(vid,3)))=permute(vid,[2 1 3]);
size(vid)

我知道这与加载文件和查找具有相同名称并附加了“_vidX”的其他文件有关,但是第 7 行究竟是做什么/意味着什么?

4

2 回答 2

2

继续丹尼尔的回答,您的问题源于您不太了解如何permute工作的事实。的目标permute是重新排列矩阵的维度,但保持矩阵的大小不变。您指定要“置换”的矩阵以及告诉您哪些输入维度映射到输出的向量。

permute(vid, [2 1 3]);意味着输入的第二维进入输出的第一维。输入的第一个维度转到输入的第二个维度,第三个维度保持不变。这样做的效果vid是一个 3D 矩阵,其中每个 2D 切片/帧都被转置,同时在最终输出中保持相同数量的切片/帧。您正在交换第二维和第一维,这基本上是转置所做的。

因此,第一个加载语句通过变量加载到您的帧中vid,并且vid123最初有一些帧,其中每个帧都被转置 - 这些对应于第一个视频。在此之后,您将加载第二个视频,该视频vid会被第二个视频中的帧覆盖。然后,您将这些框架添加到vid123. 因此,您只需将第一帧和第二帧中的帧拼凑在一起 - 转置创建一个更大的视频。

我强烈建议您重新保存它,以便两个视频被不同的变量清楚地分开,或者可能有一个包含两个视频的结构。将变量vid存储在两个单独的文件中是有问题的。

像这样的东西会起作用:

load([filename '_vid1']);
vid1 = vid;
load([filename '_vid2']);
vid2 = vid;
clear vid;
save videos;

...甚至这会起作用:

load([filename '_vid1']);
s.vid1 = vid;
load([filename '_vid2']);
s.vid2 = vid;
clear vid;   
save videos;

在第一个版本中,两个视频都存储在单独的变量中vid1vid2而第二个版本,两个视频都保存在一个结构中。

于 2016-03-18T01:36:27.850 回答
0

只是为了重写第 7 行应该如何重写:

vid123=cat(3,vid123,permute(vid,[2 1 3])

它将第三维中的两个变量连接起来。如果您打算理解原始行,只需将 end 语句放在应该使用的地方,它就会突然变得更具可读性:

vid123(:,:,end+1:end+size(vid,3))=permute(vid,[2 1 3]);

使用end+1:end+size(vid,3)它将size(vid,3)-many 新切片插入 3d 矩阵vid123

于 2016-03-18T01:31:47.550 回答