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行究竟做什么/意味着什么?
答案 0 :(得分:2)
继续丹尼尔的回答,你的问题源于你不太了解permute
的工作原理。 permute
的目标是重新排列矩阵的维度,但保持矩阵的大小不变。您可以指定要“置换”的矩阵以及一个向量,该向量可以告诉您哪些输入维度映射到输出。
permute(vid, [2 1 3]);
的含义是输入的第二个维度转到输出的第一个维度。输入的第一个维度转到输入的第二个维度,第三个维度保持不变。这样的效果是vid
是3D矩阵,其中每个2D切片/帧转置,同时在最终输出中保持相同数量的切片/帧。您正在交换第二个和第一个维度,这实际上就是转置的作用。
因此,第一个load语句通过变量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;
在第一个版本中,两个视频都存储在单独的变量vid1
和vid2
中,而第二个版本中,两个视频都保存在一个结构中。
答案 1 :(得分:0)
重写第7行应如何重写:
vid123=cat(3,vid123,permute(vid,[2 1 3])
它将第三维中的两个变量连接起来。如果您打算理解原始行,只需将结束语句放在应该使用的地方,它突然变得更具可读性:
vid123(:,:,end+1:end+size(vid,3))=permute(vid,[2 1 3]);
使用end+1:end+size(vid,3)
它会将size(vid,3)
- 许多新切片插入到3d矩阵中vid123