store data from matrix rowwise in indexed structure

조회 수: 1 (최근 30일)
Doreen
Doreen 2016년 5월 10일
댓글: Andrei Bobrov 2016년 5월 10일
Hello everyone, I have a structure 'Sample', which contains many objects (over 1000) with the same attributes. For example sample specific data is stored as a 1x2090 vector under Sample([]).YData. If I want to extract the 'YData' of sample 1 to 151 and store it in a matrix, I simply write
Select = 1:151; YData = vertcat(Sample(Select).YData);
Now I want to write selected data back to structure... Each row of a matrix should be written to the 'YData' of the corresponding sample.
Sample(Select).YData = Matrix;
doesn't work. Is there a way to implement this task in such a simple way or will only a for-loop do this job? Thanks

채택된 답변

Guillaume
Guillaume 2016년 5월 10일
편집: Guillaume 2016년 5월 10일
To create your matrix in the first place you went through two steps:
  1. Created a comma separated list out of your structure (simply by writing Sample(Select).YData)
  2. Concatenated together all the elements of the list into one matrix with vertcat
To do the inverse you have to reverse these steps
  1. Split the matrix into rows
  2. deal these rows to the structure
Unfortunately, it can't be done as a one-liner, you have to use a temporary variable
rows = num2cell(Matrix, 2); %split matrix into rows
[Sample(Select).YData] = rows{:}; %distribute rows into structure
  댓글 수: 3
Doreen
Doreen 2016년 5월 10일
Great :-) Many thanks!
Andrei Bobrov
Andrei Bobrov 2016년 5월 10일
But working in Octave:
Sample(Select) = cell2struct(num2cell(Matrix,2),{'YData'},2);

댓글을 달려면 로그인하십시오.

추가 답변 (0개)

카테고리

Help CenterFile Exchange에서 Shifting and Sorting Matrices에 대해 자세히 알아보기

Community Treasure Hunt

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

Start Hunting!

Translated by