Ignoring NaN values when multiplying?
Mostrar comentarios más antiguos
I need to multiply a range of elements with eachother, and now i discovered that if any of the elements is entered as NaN, the entire product will be NaN.
winnerportfolios=zeros(11,127);
for column=1:127
y=2;
x=firstWinnerRow(1,column);
for col=2:3:375
for nrStocks=10:10:100
winnerportfolios(y,column)=prod(HPRsorted(x:x+nrStocks,col));
y=y+1;
end
end
end
I'd like to find a way to ignore the NaN values. The only way i come to think of would be to change the NaN-values to 1...
Thank you so much in advance!
oh and ignore the awful code, I've been working with matlab for only about a month :)
1 comentario
Federal Cearpa
el 6 de Jun. de 2017
Turn all the Nan's into 1's.
Respuestas (2)
Teja Muppirala
el 22 de Abr. de 2011
"The only way i come to think of would be to change the NaN-values to 1"
That sounds like a reasonable idea to me:
X = [2 3 4; nan 2 7; 2 5 nan]
Y = X;
Y(isnan(Y)) = 1;
prod(Y)
2 comentarios
Anna
el 22 de Abr. de 2011
Jerry Gregoire
el 14 de Abr. de 2015
Jonas had a good entry dealing with this issue and why you may want to consider the implications of doing this.
Steven Lord
el 6 de Jun. de 2017
0 votos
Categorías
Más información sobre Creating and Concatenating Matrices en Centro de ayuda y File Exchange.
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!