Need help processing this

2 vues (au cours des 30 derniers jours)
I Made
I Made le 12 Mar 2013
So i have e.g data < 3x3 int 16 >
4 5 3
5 4 1
2 1 2
i wanted to got
78 60 23
and the process is like :
Column 1->(4*4*1)+(5*5*2)+(2*2*3) then Column 2->(5*5*1)+(4*4*2)+(1*1*3) then Column 3->(3*3*1+1*1*2+2*2*3)
i tried this :
[g,h]=size(data);
m = int16(1:g);
t=sum(data(:,m).*data(:,m).*m);
but i have matrix dimension problem, How can i solve,achieve this?

Réponse acceptée

Andrei Bobrov
Andrei Bobrov le 12 Mar 2013
out = cast((1:size(A,1))*double(A.*A),class(A));
  4 commentaires
I Made
I Made le 12 Mar 2013
Modifié(e) : I Made le 12 Mar 2013
Works like magic.. thanks andrei tough i don't understand yet the principle of the precision using double or using class like you mention on your first answer.
Cedric
Cedric le 13 Mar 2013
Modifié(e) : Cedric le 13 Mar 2013
Andrei type-casts A.*A to double so it can be multiplied by the vector (1:size(..)) avoiding the error that you got when you tried my solution (that I wrote without paying enough attention to the fact that A was int16). He then type-casts back to the original type afterwards (which is the type/class of A).
In my comment above, I type-cast A to double before squaring it, so the square is not truncated by int16 limits. I don't type-cast back to the type of A, because I don't think that you need that (and there would be the truncation issue as the matrix multiplication performs a weighted sum of squares with weights >=1).

Connectez-vous pour commenter.

Plus de réponses (0)

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