Variable declaration in matlab
Mostrar comentarios más antiguos
Is it necessary to declare a variable in matlab?
Respuesta aceptada
Más respuestas (4)
Aldin
el 5 de Mzo. de 2012
Yes, when in you type in command window:
a = 2; it's a number (in JAVA: integer)
a = '2'; it's a string (in JAVA String)
a = [1 2 3 4 5] it's a vector(array) (in JAVA: int array[] = new int[5])
a = [ 1 2; 3 4] it's a matrix (in JAVA: int array[][] = new int[2][2])
a = {'a',2;'b',3} it's a cell (in JAVA structure)
3 comentarios
Oleg Komarov
el 5 de Mzo. de 2012
I do not agree, because a proper declaration exists without assignment of a value.
Aldin
el 5 de Mzo. de 2012
MATLAB works with only with matrix variable!!!
Oleg Komarov
el 5 de Mzo. de 2012
What is a matrix variable?
Shalini
el 5 de Mzo. de 2012
0 votos
8 comentarios
Aldin
el 5 de Mzo. de 2012
first = input('Input first number: ');
second = input('Input second number: ');
% the result
result = first + second;
disp(result);
Aldin
el 5 de Mzo. de 2012
Or so:
first = 2; % integer first of value "2"
second = 12; %integer second of value "2"
result = first + second; %result will be 14
disp(result);
Aldin
el 5 de Mzo. de 2012
Press "Accept answer" if i was helpful
Walter Roberson
el 5 de Mzo. de 2012
Except for variables being used in code generation, variables are allowed to change type at any time.
first = 2; %a double precision (not integer!) assignment
second = int32(12); %a signed 32 bit integer assignment
first = second; %first will become a signed 32 bit integer!
second = {'hello'}; %second just became a cell array!
pavan
el 20 de Dic. de 2012
Hey,Can u tell me for second=int32(12); whether 12 is assigned first in double precision and converted to int32? or it is int 32 right from the start?
Muruganandham Subramanian
el 20 de Dic. de 2012
Editada: Muruganandham Subramanian
el 20 de Dic. de 2012
If the variable is already declared in other datatype,then it'll converts to int32()
e.g
a=2; % 'a' is double
b=int32(a) % 'b' is int32
else, it'll directly take datatype,which we mentioned or default
Walter Roberson
el 20 de Dic. de 2012
In older versions of MATLAB, int32(12) worked by having 12 evaluated in double precision first, creating a temporary (nameless) double precision variable. That temporary variable was then passed to the int32() routine, which did the conversion, creating a second temporary variable but of int32 type. That second temporary variable was returned from int32, after which the first temporary variable was deleted. The second temporary variable was then assigned to "second", which would happen by creating a permanent name for the nameless variable (not by copying its content, just naming it and holding on to it.)
In newer versions of MATLAB, int32() and similar numeric datatypes applied to constant numeric expressions of a very limited number of forms (e.g., uint64(134324342332432)) is handled at parsing time, special processing to ensure that the full precision is used; the parsing would directly create a temporary int32 variable. The assignment of that temporary variable to "second" would proceed like above, by assigning a permanent name to it rather than by copying it.
However, some testing I did a few weeks ago showed that if the numeric constant was not in one of a very limited number of formats, then even though it was numeric and constant, the special case would not be recognized, and instead the same sort of processing would be applied as for older MATLAB.
Mohashin Pathan
el 27 de Mayo de 2013
i want to initialize some double and some integer in a structure, can anyone help me how to do that
KJDS SRINIVASA RAO
el 27 de Mayo de 2013
0 votos
yes sometimes required to remove confusion
Jon Camilleri
el 15 de Nov. de 2015
0 votos
So how do I initialize a variable and read the data types available?
4 comentarios
Walter Roberson
el 16 de Nov. de 2015
You initialize a variable by assigning a value to it.
You can informally find the data type by using whos() on the variable to see information about it. You can find its data type name in a program by asking for class() of the variable.
There is no complete list of data types available, because objects created through MATLAB Object Oriented Programming are considered distinct datatypes.
The "basic" data types are:
- numeric: single(), double(), int8(), uint8(), int16(), uint16(), int32(), uint32(), int64(), uint64(). Each of these can also have a complex component
- logical: logical(), false, true (can often be converted to numeric), cannot have complex component, stored as 1 byte each
- char / string: char(), quoted strings, stored as 2 bytes each, using Unicode code points
- cell array: cell()
- structures: struct()
- double() and logical() can also exist in sparse array form
ARUN BORGOHAIN
el 25 de Jun. de 2017
Editada: Walter Roberson
el 25 de Jun. de 2017
I am using matlab_6.5 version;
v=[0 0]
x(1) = v(1);
y(1) = v(2);
fun = inline('((x-5)^2+(y-5)^2-25)')
a = fminsearch(fun, v )
% error giving(not enough input in fun???)
%---------------
fun = inline('((x(1)-5)^2+(x(2)-5)^2)')
a = fminsearch(fun, [0 0])
a =
4.9998 5.0001
%---------------------so how to dealare x,y;
It is fine with
x=x (1)& y=x (2)
Not with x & y
Stephen23
el 25 de Jun. de 2017
@ARUN BORGOHAIN: please ask a new question. Note that your question has nothing to do with declaring variables: you need to ask about how to use fminsearch properly.
Walter Roberson
el 25 de Jun. de 2017
fun0 = inline('((x-5)^2+(y-5)^2-25)')
fun = inline('fun0(xy(1),xy(2))');
a = fminsearch(fun, [0 0])
Categorías
Más información sobre Variables 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!