Error using mean: Too many input arguments.

2 次查看(过去 30 天)
Dear MATLAB experts,
I keep on getting the error described in the title of the question and I don't know how to solve it. The implemented code is the one you find below.
stock_priceStats = table();
stock_priceStatsVars = stockprice_data.Properties.VariableNames;
for i = 1:width(stockprice_data)
colData = stockprice_data.(i);
stock_priceStats.(i) = mean(colData{:});
stock_priceStats.(i) = std(colData{:});
stock_priceStats.(i) = min(colData{:});
stock_priceStats.(i) = quantile(colData{:}, .25);
stock_priceStats.(i) = median(colData{:});
stock_priceStats.(i) = quantile(colData{:}, .75);
stock_priceStats.(i) = max(colData{:});
end
stock_priceStats.Properties.Variablenames = stock_priceStatsVars;
After also typing in the command window:
which -all mean
I get the following:
/Applications/MATLAB_R2021a.app/toolbox/matlab/datafun/mean.m
/Applications/MATLAB_R2021a.app/toolbox/matlab/datatypes/duration/@duration/mean.m % duration method
/Applications/MATLAB_R2021a.app/toolbox/matlab/datatypes/datetime/@datetime/mean.m % datetime method
/Applications/MATLAB_R2021a.app/toolbox/matlab/bigdata/@tall/mean.m % tall method
/Applications/MATLAB_R2021a.app/toolbox/matlab/timeseries/@timeseries/mean.m % timeseries method
/Applications/MATLAB_R2021a.app/toolbox/nnet/deep/@dlarray/mean.m % dlarray method
I would be really grateful if you could help me out with this.
Thank you in advance.
  3 个评论
Stephen23
Stephen23 2021-9-29
The actual problem is that you are generating a comma-separated list and supplying multiple inputs to MEAN:
mean(colData{:})
% ^^^ comma-separated list
What do you expect that to achieve?
DGM
DGM 2021-9-29
Can you provide an example of stockprice_data so that I can replicate the issue?

请先登录,再进行评论。

采纳的回答

DGM
DGM 2021-9-29
编辑:DGM 2021-9-29
I'm not sure how these arrays are shaped or what the contents are, but I'm guessing you can do something like this:
mean(vertcat(colData{:}))
to collect the multiple outputs of coldata{:} into a single vector.
If that's the case, it would be more efficient to avoid replicating the operation:
stock_priceStats = table();
stock_priceStatsVars = stockprice_data.Properties.VariableNames;
for i = 1:width(stockprice_data)
colData = stockprice_data.(i);
colData = vertcat(colData{:});
% alternatively, you may simply be able to do it in one line
stock_priceStats.(i) = mean(colData);
stock_priceStats.(i) = std(colData);
stock_priceStats.(i) = min(colData);
stock_priceStats.(i) = quantile(colData, .25);
stock_priceStats.(i) = median(colData);
stock_priceStats.(i) = quantile(colData, .75);
stock_priceStats.(i) = max(colData);
end
  3 个评论
DGM
DGM 2021-9-29
Maybe something like this
stock_priceStats = table();
stock_priceStatsVars = stockprice_data.Properties.VariableNames;
for i = 1:width(stockprice_data)
colData = stockprice_data.(i);
colData = vertcat(colData{:});
stock_priceStats.(i) = [mean(colData); std(colData); min(colData); ...
quantile(colData, .25); median(colData); ...
quantile(colData, .75); max(colData)];
end
chiefjia
chiefjia 2021-9-29
编辑:chiefjia 2021-9-29
Absolute legend, this helps a lot! Thank you!

请先登录,再进行评论。

更多回答(0 个)

类别

Help CenterFile Exchange 中查找有关 Creating and Concatenating Matrices 的更多信息

Community Treasure Hunt

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

Start Hunting!

Translated by