Creating a struct with means and standard deviations

조회 수: 3 (최근 30일)
BA
BA 2022년 9월 16일
댓글: BA 2022년 9월 16일
I'd like to create a script that loops through multiple subjects and creates a new structure with doubles in it.
First Column of Master Table: I want the SubjectID but I only want it once, I don't want it repeating like it is in the dataset I've attached.
Second Column of Master Table: I want it to lead to a struct with the means of each of the six events. So in the new struct, I want the first column of the first row to be for event 1_a, second column first row event 2_a, etc.
Third Column of Master Table: I want it to lead to a struct with the standard deviation of each of the six events.
Here's an example of what I want it to look like:
The examples of mean and standard deviation doubles are only for one subject. I'd like to loop this for every subject in the data table to create a master struct.

채택된 답변

Chris
Chris 2022년 9월 16일
편집: Chris 2022년 9월 16일
It looks like you want an array of structs. Use strings or uint64 for the IDs
S = struct('id',uint64(123456),'mean',rand(3),'stdev',rand(1,3))
S = struct with fields:
id: 123456 mean: [3×3 double] stdev: [0.7411 0.1904 0.5026]
% Add new data
for idx = 2:4
S(idx).mean = rand(3);
S(idx).stdev = rand(1,3);
S(idx).id = uint64(randi(1e9));
end
S
S = 1×4 struct array with fields:
id mean stdev
% Retrieve data
x = S(3).stdev
x = 1×3
0.6080 0.0728 0.3028
y = [S(1:2).id]
y = 1×2
123456 614065544
  댓글 수: 5
Chris
Chris 2022년 9월 16일
편집: Chris 2022년 9월 16일
Unstack sounds useful, but I'm unfamiliar with it and man, I need to learn some table stuff.
@BA How about something like this?
EventData = readtable('Event_1_2.xlsx');
vars = T.Properties.VariableNames;
[u,~,ic] = unique(EventData.UserID);
for idx = 1:numel(u)
Updating(idx).ID = u(idx);
T = EventData(ic==idx,2:end);
Updating(idx).stdev = array2table(std(T{:,:}),'VariableNames',vars);
Updating(idx).mean = array2table(mean(T{:,:}),'VariableNames',vars);
end
BA
BA 2022년 9월 16일
Thank you! That works. Appreciate you for helping me out!

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

추가 답변 (0개)

카테고리

Help CenterFile Exchange에서 Logical에 대해 자세히 알아보기

태그

제품


릴리스

R2022a

Community Treasure Hunt

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

Start Hunting!

Translated by