Indexing a cell array according to another cell array
Show older comments
So I have two cell arrays, each represent onset and offset times of events, so they have the same size and they correspond to each other, for example:
A = {[2,3,4],[3,6],[5,7,9,10]};
B = {[2.5,4.2,4.7],[3.2,7.4],[6.2,7.6,9.4,11.3]}
I now was able to delete certain entries in A according to a different indexing vector c,let's say new A is (anything equals to 3 or between 7 to 9 is deleted):
A = {[2,4],[6],[5,10]}
How do I delete the corresponding entries in B? I want to achieve:
B = {[2.5,4.7],[7.4],[6.2,11.3]}
In other words delete the second, first, and second and third entires in the three cells in B. I tried to do it after entries were deleted from A, but the sizes and entries no longer match. It seems I have to somehow index A and B at the beginning before I mess with A, but I am not sure how to do this...
Accepted Answer
More Answers (1)
Azzi Abdelmalek
on 24 Mar 2016
A = {[2,3,4],[3,6],[5,7,9,10]};
B = {[2.5,4.2,4.7],[3.2,7.4],[6.2,7.6,9.4,11.3]}
idx=cellfun(@(x) x~=3 & ~(x<=9 & x>=7),A,'un',0)
C1=cellfun(@(x,y) x(y),A,idx,'un',0)
C2=cellfun(@(x,y) x(y),B,idx,'un',0)
celldisp(C1)
celldisp(C2)
10 Comments
alicia che
on 1 Apr 2016
Azzi Abdelmalek
on 1 Apr 2016
idx for what?
alicia che
on 1 Apr 2016
Azzi Abdelmalek
on 1 Apr 2016
And how to apply C to your cell array?
alicia che
on 4 Apr 2016
Edited: Azzi Abdelmalek
on 4 Apr 2016
Azzi Abdelmalek
on 4 Apr 2016
C does not contain 10 element but 12.
alicia che
on 4 Apr 2016
Azzi Abdelmalek
on 4 Apr 2016
Ok, but A contains just 9 elements!
alicia che
on 5 Apr 2016
Azzi Abdelmalek
on 5 Apr 2016
To make your question clear, post an example and explain clearly what you want, and post the expected result
Categories
Find more on Matrix Indexing in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!