三次元行列の作成
14 Ansichten (letzte 30 Tage)
Ältere Kommentare anzeigen
shunya hara
am 22 Jul. 2020
Kommentiert: Shunichi Kusano
am 25 Jul. 2020
画像(1000枚)の輝度値を要素とした三次元行列を作成したいです。
cat関数を用いて、画像を三次元に拡張しようと考えたのですが時間がかかります。
もっと早く作成する方法はありますか?
gray スケールの画像1000枚をfor構文とcat関数を用いて一枚ずつ三次元方向にくっつけています。
0 Kommentare
Akzeptierte Antwort
Shunichi Kusano
am 22 Jul. 2020
b = zeros(m,n,1000);
で始めに1000枚分の行列を確保してから,for文で一枚ずつ画像入れてあげると早くできます。
% sample
img = rand(500,500);
tic
imgall = zeros(500,500,1000);
for i = 1:1000
imgall(:,:,i) = img;
end
toc % 経過時間は 0.936728 秒です。
tic
imgall = img;
for i = 2:1000
imgall = cat(3,imgall,img);
end
toc % 経過時間は 586.288862 秒です。
5 Kommentare
Shunichi Kusano
am 25 Jul. 2020
100枚に減らしたんでしょうか。
3から始まっていていいのでしたら、他には特に気になるところはないです。・・・とおもったら、C(;,;,n)=Aのところは
C(:,:,n) = A; % セミコロンではなくてコロン
です。
Weitere Antworten (1)
madhan ravi
am 22 Jul. 2020
Bearbeitet: madhan ravi
am 22 Jul. 2020
I = num2cell(Images);
W = cat(3, I{:});
2 Kommentare
madhan ravi
am 22 Jul. 2020
n = 4 : 1079;
A = cell(numel(n), 1);
for n = n
A{k} = imread(a(n).name);
k = k + 1;
end
W = cat(3, A{:});
Siehe auch
Kategorien
Mehr zu Matrix Indexing finden Sie in Help Center und File Exchange
Produkte
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!