How to seperate fractional and decimal part in a real number
Mostrar comentarios más antiguos
Hi, Please help me in seperating fractional and decimal part in a real number. For example: If the value is '1.23', I need to seperate decimal part '1' and 'fractional part '0.23'.
Thanks and regards, soumya..
5 comentarios
Jan
el 16 de Nov. de 2011
Are you talking of numbers or strings? The quotes in '1.23' might be misleading.
Jerry Gregoire
el 4 de Oct. de 2012
Jan Its my pet peeve when a poster poses a question and it is responded to with another unnecessary question. Yes, in Matlab syntax, '0.23' indicates a string, but it is really obvious that he meant 0.23. I guess my wish to responders is simply, 'Just answer the question already' !!
Jan
el 13 de Feb. de 2016
Some years later: @Jerry: Many questions in this forum are based on the inaccurate knowledge about the classes of variables. I tend to ask for a clarification instead of speculating of what seems obvious.
Jeremy Wood
el 5 de Jul. de 2017
Try using the floor operator to get the greatest integer below your number then subtract out your integer. For example 1.5 - floor(1.5) 0.5. It's trickier with negative numbers though so try using the absolute value of the number then when you get your fractional part multiply it by -1 so for -1.5 you would do -1*(1.5 - floor(1.5))
Bart McCoy
el 25 de Jul. de 2018
EXTRACTING THE INTEGER PART
Extracting the integer part can be the most tricky part. MATLAB's "fix" function rounds toward zero, which is useful because it extracts the integer part of BOTH positive and negative numbers. It returns doubles and also works on NxM arrays.
By contrast, the "ceil" function always rounds upward, to the next integer in the POSITIVE direction; "floor" always rounds down, to the next integer in the NEGATIVE direction. Use whatever makes sense, but note:
INTEGER EXTRACTION: fix(pi) = 3; fix(-pi) = -3;
ROUNDING UP: ceil(pi) = 4; ceil(-pi) = -3;
ROUNDING DOWN: floor(pi) = 3; floor(-pi)= -4;
EXTRACTING THE FRACTIONAL PART:
fractional_part = value - fix(value);
Respuesta aceptada
Más respuestas (5)
Naz
el 16 de Nov. de 2011
number=1.23;
integ=floor(number);
fract=number-integ;
1 comentario
Walter Roberson
el 16 de Nov. de 2011
That fails on negative numbers. For negative numbers, you need fract=number-ceil(number)
Revant Adlakha
el 24 de Feb. de 2021
Editada: Revant Adlakha
el 24 de Feb. de 2021
How about this?
sign(x)*(abs(x) - floor(abs(x)))
% Number -> x = -1.23
% Answer -> -0.23
% Number -> x = 1.23
% Answer -> 0.23
1 comentario
Setsuna Yuuki.
el 15 de Oct. de 2022
Thanks!
Resam Makvandi
el 26 de Dic. de 2012
Editada: Walter Roberson
el 24 de Feb. de 2021
i think the better way is to use:
number = 1.23;
integ = fix(number);
fract = abs(number - integ);
it works for both negative and positive values.
2 comentarios
KOMAL VERMA
el 25 de En. de 2023
what if there is array
like x=[0.2, 1.2 1.0]
Did you try it?
x = [0.2, 1.2 1.0]
integ = fix(x)
fract = abs(x - integ)
Are Mjaavatten
el 9 de Feb. de 2016
Editada: Are Mjaavatten
el 9 de Feb. de 2016
mod(number,1)
5 comentarios
Walter Roberson
el 9 de Feb. de 2016
>> mod(-0.123,1)
ans =
0.877
However, 0.877 is neither the whole number nor the fraction of -0.123
Are Mjaavatten
el 10 de Feb. de 2016
Walter is right of course. To work for both positive and negative numbers my solution must be mofified to
mod(abs(number),1)*sign(number)
or just
mod(abs(number),1)
depending on you definition of the fraction part. I prefer these to the accepted answer because it does not require intermediate variables, but this is a matter of taste.
Walter Roberson
el 10 de Feb. de 2016
The accepted answer by Naz does not use any intermediate variables. The task is to return each of the parts. Naz's solution happens to calculate one part and use it to calculate the other as well, but that does not make either one an intermediate variable.
Are Mjaavatten
el 13 de Feb. de 2016
Point taken. I should be old enough to have learned to read the problem definition. Still, I think it is nice to have a single command for the fractional part.
Jan
el 13 de Feb. de 2016
What about rem instead of mod?
abs(rem(-0.123, 1)) % => 0.123
Kh.Ehsanur Rahman
el 13 de Feb. de 2016
0 votos
what if the number is -1.23.
Categorías
Más información sobre Operators and Elementary Operations 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!