Borrar filtros
Borrar filtros

Decompose Data int a Matrix

1 visualización (últimos 30 días)
Mansour Aljohani
Mansour Aljohani el 29 de Jul. de 2015
Comentada: Star Strider el 10 de Ag. de 2015
I got how to locate my data from the signal in the following link: http://www.mathworks.com/matlabcentral/answers/229678#answer_185935
but how to decompose my data int a matrix. I attached my row data.
  2 comentarios
Azzi Abdelmalek
Azzi Abdelmalek el 29 de Jul. de 2015
Decompose Data int a Matrix? What does that mean?
Mansour Aljohani
Mansour Aljohani el 30 de Jul. de 2015
each column in the matrix has one pulse from the row data in this example i have 8 column.

Iniciar sesión para comentar.

Respuesta aceptada

Star Strider
Star Strider el 30 de Jul. de 2015
The data you want is when the ‘lowSignal’ vector is equal to 1. If each column in your matrix has one pulse from that record, the separation has already been done. By definition, each column is a pulse, so if your matrix is ‘M’ and it is of size (Nx8), where ‘N’ is the number of rows, to get the first and eighth pulses:
Pulse_1 = M(:,1);
Pulse_8 = M(:,8);
  8 comentarios
Mansour Aljohani
Mansour Aljohani el 9 de Ag. de 2015
Dear Strider,
why i got this
Error in threshold (line 33) sig_mtx(:,k1) = signal(epk_start(k1):epk_end(k1));
and thank you again.
Star Strider
Star Strider el 9 de Ag. de 2015
I have no idea. My code worked with your data, or I’d not have posted it.
What was the error?

Iniciar sesión para comentar.

Más respuestas (1)

Mansour Aljohani
Mansour Aljohani el 9 de Ag. de 2015
the error is in this, it said
Subscripted assignment dimension mismatch.
Error in threshold (line 33)
sig_mtx(:,k1) = signal(epk_start(k1):epk_end(k1));
  2 comentarios
Mansour Aljohani
Mansour Aljohani el 9 de Ag. de 2015
Now it is work thank you so much for you help sir
Star Strider
Star Strider el 10 de Ag. de 2015
My pleasure.
That usually means the array sizes between the LHS and RHS of an assignment don’t match. My code assumes all the ‘epochs’ (as I called them) were of equal lengths, since they were the same in the file you provided.
Change the loop to:
for k1 = 1:length(epk_start)
sig_mtx{k1} = signal(epk_start(k1):epk_end(k1));
tim_mtx{k1} = time_vct(epk_start(k1):epk_end(k1));
end
This converts ‘sig_mtx’ and tim_mtx to cell arrays. That should at least solve the current problem. However you will have to program subsequent assignments involving them to accommodate the different lengths, and to change the cell arrays to double arrays in your code. See the documentation on Cell Arrays for details.

Iniciar sesión para comentar.

Etiquetas

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by