Effacer les filtres
Effacer les filtres

logical indexing within groups

4 vues (au cours des 30 derniers jours)
EM
EM le 24 Juil 2017
Modifié(e) : Andrei Bobrov le 24 Juil 2017
I have a panel data set such that N observations occur over t-time periods. I've created a unique id number for each N-observation which repeats over t-time periods. See photo for example.
Next, I'd like to extract all the individuals such that hsClass==5 & hsClass<5.
Normally a table (table name is panel1) indexing could be achieved by
rows = panel1.hsClass==5 & panel1.hsClass<5;
panel2 = panel1(rows,:);
However, this results in a table with zero rows. In my case I want the indexing to be performed over the grouping variable (G). How can this be done?
  2 commentaires
per isakson
per isakson le 24 Juil 2017
Andrei Bobrov
Andrei Bobrov le 24 Juil 2017
Modifié(e) : Andrei Bobrov le 24 Juil 2017
Please attach your data as mat file.

Connectez-vous pour commenter.

Réponses (1)

Walter Roberson
Walter Roberson le 24 Juil 2017
[uG, ~, Gidx] = unique(panel1.G);
group_has_a_5 = accumarray(Gidx, panel1.hsclass == 5) >= 1;
row_mask = ismember(panel1.G, uG(group_has_a_5) );
panel2 = panel1(row_mask,:);

Catégories

En savoir plus sur Matrix Indexing dans Help Center et File Exchange

Produits

Community Treasure Hunt

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

Start Hunting!

Translated by