二値の配列の中で、同じ値が任意の点数分、連続する位置を検出するにはどうすればいいですか?
14 visualizaciones (últimos 30 días)
Mostrar comentarios más antiguos
MathWorks Support Team
el 28 de Sept. de 2021
Respondida: Atsushi Ueno
el 28 de Sept. de 2021
0,1のみからなる1×n の行列 x に対して、0から1へ変化した後、1が100個以上続くような点を計算するにはどうすればよいか、教えてください。
Respuesta aceptada
MathWorks Support Team
el 28 de Sept. de 2021
Signal Processing Toolbox の pulsewidth 関数を用いることで計算できます。
以下に例を示します。ここでは、1が 5点以上続くインデックスを検出しています。
入力信号を[x 0]としているのは、xの最後の要素が1の場合、最後に立ち下げておかないとパルスと判定されないためです。
>> rng(1) % reproducibility
% サンプル信号の作成
>> x = rand(1,20)<0.5
x =
1×20 の logical 配列
1 0 1 1 1 1 1 1 1 0 1 0 1 0 1 0 1 0 1 1
>> [W,INITCROSS] = pulsewidth([x 0]); %パルス幅を計算
>> ind = ceil(INITCROSS(W>=5)) % 5点以上続くインデックスの開始位置を算出
ind =
3
0 comentarios
Más respuestas (1)
Atsushi Ueno
el 28 de Sept. de 2021
予め1が100個続く1×100の行列 y を用意しておいて、1×n の行列 x に対する畳み込みの結果を得る事で、1が100個以上続くような点が判ります。(100個は長過ぎるので、例として上記回答と同じ5個にしました)
x = [1 0 1 1 1 1 1 1 1 0 1 0 1 0 1 0 1 0 1 1]
y = ones(1, 5)
z = conv(x, y)
end_idx = find(z>=5) % 7番目、8番目、9番目の時点で1が5点以上続いている
start_idx = end_idx - (5 - 1) % 長さ-1を減算し開始位置のインデックスにする
0 comentarios
Ver también
Categorías
Más información sobre Logical en Help Center y File Exchange.
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!