フィルターのクリア

How can i extract Index values of different cell arrays

8 ビュー (過去 30 日間)
Ram
Ram 2018 年 7 月 29 日
コメント済み: Ram 2018 年 7 月 30 日
I want to extract the cell arrays w.r.to the index num,
for w =1:length(mydata)
%[~,I]= find(mydata{w, 2}(:,2)) = find(mydata{w, 1}(:,1));
for o = 1:length(mydata{w,2})
index = find(mydata{w, 2}(:,2) == mydata{w, 1}(:,1)== o);
mydata{w,3} = index;
end
end
I have a cell which contains max and its index values in each row. Now i want to find max index values in another cell and extract those values( matrix 1*2, here i want to extract only 1st col value only). for ex. [M,I] = [2,295]. 295 index value of its max value in certain row, let say (6,26321) is the extracted index value in another cell. extract value is 6(1st col) similarly all other row cells matrix. Thanks in advance.
  5 件のコメント
Ram
Ram 2018 年 7 月 30 日
@jonas thanks for your reply. From 1*2 matrix i have max and index values. for example(from data),(0.3076,690) is our max and index values. Now i want to extract the values from 999*2 matrix. where index is 690 ie.,(8.1510,110.9065). but here i want to extract first col only for each cell array matrix. i have same data for min and index values. later i want to find distance between them.
Ram
Ram 2018 年 7 月 30 日
編集済み: Ram 2018 年 7 月 30 日
@image analyst thanks for your support. above code writtens only my max and index values again, But this is not my required output. here input matrix is 1*2 which has [max ind] values. but we consider only index values in order to find index values in 999*2 matrix. as i said in above. And here other cell/rows cells means to find all index values for each cell (999*2) array from the 1*2 matrix. sorry for inconvienence about explanation.

サインインしてコメントする。

採用された回答

jonas
jonas 2018 年 7 月 30 日
編集済み: jonas 2018 年 7 月 30 日
Something like this should work.
s = load('mydata21.mat')
s=s.mydata21;
c=s(:,2) %arrays with indices
d=s(:,1) %arrays with values
out=cellfun(@(x,y)y(x(2),1),c,d)
  6 件のコメント
jonas
jonas 2018 年 7 月 30 日
編集済み: jonas 2018 年 7 月 30 日
1. Cellfun is just a clean way of performing operation on multiple cells. In this case you can do the same with a simple loop:
%%Load data
s = load('mydata21.mat')
s=s.mydata21;
%%Preallocate
out=nan(length(s))
%%Loop over each row
for i=1:length(s)
out(i)=s{i,1}(s{i,2}(2));
end
2. If your data is already loaded, just delete the first line and replace the variable with whatever you call it? I suppose you should replace s by mydata?
3. In the cellfun or the loop, just change the column index from 1 to 2.
Ram
Ram 2018 年 7 月 30 日
@jonas Thanks alot. You are just genius and saved my time.

サインインしてコメントする。

その他の回答 (0 件)

カテゴリ

Help Center および File ExchangeMATLAB についてさらに検索

タグ

製品

Community Treasure Hunt

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

Start Hunting!

Translated by