error in std for 3d matrix

1 vue (au cours des 30 derniers jours)
Anastasia
Anastasia le 12 Déc 2016
Commenté : Guillaume le 13 Déc 2016
Hey guys!
I am trying to find the std of a 3D matrix, where size(X) is 207 x 201 x 34. Since I must reshape to find std, I am using this formula: std(reshape(X,1,207*201*34)).
And I obtain this error: Error in std (line 31) y = sqrt(var(varargin{:}));
When I look at the syntax, I thought of using std(reshape(X,1,207*201*34), 0, 3), where 3 is for 3D, however I still obtain the same error.
What I am missing?
Thank you very much in advance!
  2 commentaires
Steven Lord
Steven Lord le 12 Déc 2016
What is the full text of the error message (including everything printed in red?)
Anastasia
Anastasia le 13 Déc 2016
Modifié(e) : Anastasia le 13 Déc 2016
Hello, this is the full text of the error message:
Error using var (line 58) First argument must be single or double.
Error in std (line 31) y = sqrt(var(varargin{:}));
Error in Code3D (line 27) th=mean(mean(mean(X))) + std(reshape(X,1,207*201*34));
Is the problem that X is nor single nor double, but 207*201*34? How can I fix that?
Thank you!

Connectez-vous pour commenter.

Réponses (2)

Isabella Osetinsky-Tzidaki
Isabella Osetinsky-Tzidaki le 12 Déc 2016
try std(x(:))
  1 commentaire
Anastasia
Anastasia le 13 Déc 2016
Hello! Thank you for your answer but I obtain the same error...

Connectez-vous pour commenter.


Guillaume
Guillaume le 13 Déc 2016
Error: First argument must be single or double
Well, clearly, your first argument (a transform of X) is not single or double. So what is:
class(X)
If it's an integer type:
Xdouble = double(X);
th = mean(Xdouble(:)) + std(Xdouble(:));
  2 commentaires
Anastasia
Anastasia le 13 Déc 2016
The class is uint16. I tried it and it works, is it correct to use the code you gave me with a uint16 class?
Thanks!
Guillaume
Guillaume le 13 Déc 2016
Without context it's impossible to say if it's correct or not. Certainly, if you want the standard deviation of your integers, you have to convert them to double. If an integer result is then required, you can convert the output back to uint16 (with the loss of precision that it entails).

Connectez-vous pour commenter.

Catégories

En savoir plus sur Logical dans Help Center et File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by