필터 지우기
필터 지우기

conversion of double to int

조회 수: 15 (최근 30일)
SNEHA P S
SNEHA P S 2017년 7월 21일
댓글: Jan 2017년 7월 21일
i had an array of 1*10 double named Q(i). I want to find modulo function of these 10 values with 256. But am getting wrong answers. May be its the problem of types. Will you please help me to solve?
  댓글 수: 5
SNEHA P S
SNEHA P S 2017년 7월 21일
sorry, Q(7) value is like 4.078e+09. And when use mod function with 256 the exact value is 128. And am geeting 25.8600.
Walter Roberson
Walter Roberson 2017년 7월 21일
Give the command
format long g
And then display the Q value again

댓글을 달려면 로그인하십시오.

채택된 답변

Walter Roberson
Walter Roberson 2017년 7월 21일
2^53 = 9007199254740992 is the largest integer expressed in double precision that you can reliably take mod() 10 of. After that, the difference between adjacent representable double precision numbers becomes more than 1.
You can extend the range by using uint64(), allowing you to get to 18446744073709551615 . Beyond that you would need to use the Symbolic Toolbox, or use one of the extended precision File Exchange contributions.
  댓글 수: 2
SNEHA P S
SNEHA P S 2017년 7월 21일
when iam trying to do the same in the command window using the exact numerical value ie., 4.078e+09, am getting it right. And its get wrong when am using Q(7) instead of value.
Jan
Jan 2017년 7월 21일
@SNEHA P S: Then compare the two values:
Q(7) - 4.078e+09
Note that the short format for the command window does not let you distinguish 4078000000 and 4078000001 or 4077999999.

댓글을 달려면 로그인하십시오.

추가 답변 (0개)

카테고리

Help CenterFile Exchange에서 Numeric Types에 대해 자세히 알아보기

태그

Community Treasure Hunt

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

Start Hunting!

Translated by