Finding minimum output value for same inputs in a table

1 Ansicht (letzte 30 Tage)
antje668
antje668 am 28 Mär. 2022
Kommentiert: antje668 am 28 Mär. 2022
I am a new user of matlab and have a question about tables.
So I have a table called myTable with three different inputs (x,y,z) and one output (fct_total), for some of the inputs I sometimes have different outputs (see higlighted rows in screenshot)
I wonder if there is any way using for example logical indexing to select the smallest output (fct_total) in the cases where inputs are the same and then place the inputs and the minimum value of the output in a separate table?

Akzeptierte Antwort

Scott MacKenzie
Scott MacKenzie am 28 Mär. 2022
Is your table consistently organized as in the image; i.e., 36 rows repeating with the same values execpt for the last column (fct_total)? If so, this code will create a column vector containing the miminum values in the fct_total column for each x-y-z combination:
d = reshape(myTable.fct_total, 36, []);
min_d = min(d, [], 2);
Then, create a new table using the min_d values and the x-y-z combinations.
  1 Kommentar
antje668
antje668 am 28 Mär. 2022
Hi Scott,
Thank you for your reply and I realized that I should have been more specific, there are also other outputs, but these I want to keep exactly as they are (See screenshot 1).
So: I want to find the minimum value for fct_total at the points where x, y and z have the same values and at the same time keep the other outputs as they are at the point where fct_total is minimized.
And it's not always consistent as in the figure in my previous post. After one iteration, a table can look like screenshot 2 (6 rows in total), where I have highlighted the rows with the same x y z values.

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (1)

Davide Masiello
Davide Masiello am 28 Mär. 2022
Bearbeitet: Davide Masiello am 28 Mär. 2022
clear,clc
% The following matrix has two rows which have same x-y-z but different
% output (namely, first and last rows)
A = rand(9,4);
A = [A;A(1,:)];
A(end,end) = A(1,end)*2
A = 10×4
0.9887 0.6494 0.1059 0.8865 0.0213 0.2678 0.9163 0.4090 0.4932 0.3351 0.9426 0.5517 0.7167 0.2276 0.1898 0.4658 0.3403 0.8453 0.0329 0.9692 0.2633 0.0325 0.0697 0.7364 0.4317 0.2285 0.7808 0.2586 0.4510 0.7312 0.0857 0.6937 0.1473 0.2083 0.2359 0.9424 0.9887 0.6494 0.1059 1.7730
% Extract the smallest of the two values
xyz = A(1,1:3); % This is the input that has two possible outputs
output = min(A(all(A(:,1:3)==xyz,2))) % Mimimum output
output = 0.9887

Kategorien

Mehr zu Tables finden Sie in Help Center und File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by