Error using matlab.internal.math.checkDataVariables Invalid grouping variables.
Mostra commenti meno recenti
kindly help me solve this issue
load("stormData");
summaryRegionCosts = groupsummary(stormData, "stormData.Region",['min','max','median','mean'] , "stormData.Total_Cost")
stormDataPos = stormData.Total_cost> 0
summaryRegionPosCosts = groupsummary(stormData, "stormData.Region", ['min','max','median','mean'],"stormData.stormDataPos")

1 Commento
Juan Carlos Hernandez
il 18 Feb 2023
Hi,
Here is your problem solved:
load("stormData");
summaryRegionCosts=groupsummary(stormData,"Region",["min","median","mean","max"],"Total_Cost")
stormDataPos=stormData(stormData.Total_Cost>=1,:)
summaryRegionPosCosts=groupsummary(stormDataPos,"Region",{"min","median","mean","max"},"Total_Cost")
Risposte (1)
Steven Lord
il 20 Ago 2022
0 voti
The second input for the groupsummary function as you're calling it should be the name of a variable in your table. "stormData.Region" isn't the name of a variable, it's an expression that would extract a variable in the table. Try using just "Region" in your call instead.
15 Commenti
Umair Ejaz
il 20 Ago 2022
Umair Ejaz
il 20 Ago 2022
Umair Ejaz
il 20 Ago 2022
Walter Roberson
il 21 Ago 2022
"To specify multiple computations at a time, list the options in a cell array, such as {'mean','median'} or {myFun1,myFun2}."
You did not use a cell array.
Umair Ejaz
il 21 Ago 2022
Umair Ejaz
il 21 Ago 2022
Simon Chan
il 21 Ago 2022
Could you show us what is the output of the following code?
stormData.Properties.VariableNames
Umair Ejaz
il 21 Ago 2022
Umair Ejaz
il 21 Ago 2022
Walter Roberson
il 22 Ago 2022
Do not use a cell array of string objects. Use either a cell array of character vectors or else a string vector.
That is, {'this', 'that'} or ["this", "that"] but not {"this", "that"}
Steven Lord
il 22 Ago 2022
Your table doesn't have a variable named Region. For that second input in your call to groupsummary you need to use one of those 13 names in the output above. SuperRegion seems closest to Region.
Walter Roberson
il 22 Ago 2022
"Region" is present if you look back to the table output in the original Question.
It does not appear in the list here because the list here truncated, with only 8 variable names visible on the list before the right hand margin, but the column count shows the second line picks up at 12. So 3 variables are missing, and the original table shows that Region is right before SuperRegion.
Umair Ejaz
il 22 Ago 2022
Umair Ejaz
il 22 Ago 2022
Walter Roberson
il 23 Ago 2022
You are attempting to pass in a logical mask stormDatapos as the 4th parameter to groupsummary, with the first parameter being a table
When you use 4 parameters to groupsummary and the first one is a table, the permitted syntaxes are
G = groupsummary(T,GROUPVARS,GROUPBINS,METHOD)
G = groupsummary(T,GROUPVARS,METHOD,DATAVARS)
Your {'min', 'max', 'median', 'mean'} or ["min", "max", "median", "mean"] is not grouping bins, so the first of the two possibilities does not apply.
Your logical vector is not a data variable name within the table, so the second of the two possibilities does not appy.
If you want to summarize only for a subset of a table, you need to construct the subset first and summarize on it. For example,
sdss = stormData(stormDataPos, :);
summaryRegionPostCosts = groupsummary(sdss, "Region", ["min", "max", "median", "mean"])
In practice you will probably need to add a list of variables to apply the summary to, as it is not clear that taking mean() of your categorical SuperRegion is meaningful.
Categorie
Scopri di più su Introduction to Installation and Licensing in Centro assistenza e File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!


