Azzera filtri
Azzera filtri

error code on cumsum

1 visualizzazione (ultimi 30 giorni)
Ralph
Ralph il 23 Feb 2014
Commentato: Ralph il 23 Feb 2014
I am attempting to run: A = 1 - cumsum(C)/sum(C); where C is a long column vector. I receive error "??? Error using ==> cumsum CUMSUM is not supported for integer input." What does it mean?
  2 Commenti
per isakson
per isakson il 23 Feb 2014
Modificato: per isakson il 23 Feb 2014
The code looks ok. Make this check
which cumsum -all
what does it say? And what does
class( C )
say? And which Matlab release do you use?
Ralph
Ralph il 23 Feb 2014
response to 'which cumsum -all' EDU>> which cumsum -all built-in (C:\Program Files (x86)\MATLAB\R2010a Student\toolbox\matlab\datafun\@single\cumsum) % single method
built-in (C:\Program Files (x86)\MATLAB\R2010a Student\toolbox\matlab\datafun\@double\cumsum) % double method
built-in (C:\Program Files (x86)\MATLAB\R2010a Student\toolbox\matlab\datafun\@logical\cumsum) % logical method
built-in (C:\Program Files (x86)\MATLAB\R2010a Student\toolbox\matlab\datafun\@uint8\cumsum) % uint8 method
built-in (C:\Program Files (x86)\MATLAB\R2010a Student\toolbox\matlab\datafun\@int8\cumsum) % int8 method
built-in (C:\Program Files (x86)\MATLAB\R2010a Student\toolbox\matlab\datafun\@uint16\cumsum) % uint16 method
built-in (C:\Program Files (x86)\MATLAB\R2010a Student\toolbox\matlab\datafun\@int16\cumsum) % int16 method
built-in (C:\Program Files (x86)\MATLAB\R2010a Student\toolbox\matlab\datafun\@uint32\cumsum) % uint32 method
built-in (C:\Program Files (x86)\MATLAB\R2010a Student\toolbox\matlab\datafun\@int32\cumsum) % int32 method
Response to class (C) EDU>> class(C) ans = uint8
I have Matlab R2010a

Accedi per commentare.

Risposta accettata

Image Analyst
Image Analyst il 23 Feb 2014
Modificato: Image Analyst il 23 Feb 2014
Try this. It works for me:
C = int32(randi(9, 1, 10)) % Array of integers.
A = 1 - cumsum(C) / sum(C)
  3 Commenti
Image Analyst
Image Analyst il 23 Feb 2014
Yes, MATLAB has an unintuitive of promoting/casting variable types. If C is double, it's fine. Regardless I can't find a way to duplicate the error the Ralph posted. Perhaps he can give some code that illustrates the error.
Ralph
Ralph il 23 Feb 2014
The suggestion above to use int32() provided an idea on how to proceed. i did not know how to identify what format my data was in, so the class() command helped with this. My data was uint8. Do I used double() to change the format of my data, and I got passed the cumsum error. Thanks for the assistance.

Accedi per commentare.

Più risposte (0)

Tag

Community Treasure Hunt

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

Start Hunting!

Translated by