how to find max of 1000 values which are rows,i wrote a code it showed just one value and index that is not the max
조회 수: 1 (최근 30일)
이전 댓글 표시
filename='realtimevalues.xlsx';
num=xlsread(filename);
y=filename(1,:);
[val idx]=max(y(:))
댓글 수: 0
채택된 답변
Image Analyst
2016년 2월 17일
num is a 2D array of numbers, or it may be depending on how your data area arranged in the workbook. y is the first character of filename, which is 'r'. I think you want
y = num(1, :); % Extract first row only.
댓글 수: 2
Titus Edelhofer
2016년 2월 17일
Hmm, in the original post it's
y = filename(1,:)
?
y=num(:)
or
y=num(1,:)
both should give reasonable results, depending of what is searched for ...
추가 답변 (1개)
Titus Edelhofer
2016년 2월 17일
Hi Shina,
what exactly is the question: you think val is not the maximum of y? I don't see how this can happen ... Or are you interested in all indices where y is taking it's maximum? In this case you could do something like
idx = find(y(:)==max(y(:)));
Note though, that this is sensitive to floating point accuracy, so if you have
y = [1 1.0000000001 1]
this would find only idx=2.
Titus
참고 항목
카테고리
Help Center 및 File Exchange에서 Startup and Shutdown에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!