Info

이 질문은 마감되었습니다. 편집하거나 답변을 올리려면 질문을 다시 여십시오.

Error while assigning a variable

조회 수: 1 (최근 30일)
Himanshu Garg
Himanshu Garg 2020년 7월 1일
마감: MATLAB Answer Bot 2021년 8월 20일
if I assign x a value of 16.000001 then it stores 16.00000100000001... and if I assign x avalue of 15.000001 then it stores 15.00000099999999.. . How to remove this error

답변 (2개)

dipak nigam
dipak nigam 2020년 7월 2일
You can refer to this answer to understand the above behaviour.
A possible workaround is to define these values as:
xN = 15000001;
yN = 16000001;
D = 1000000;
and then use them in your calculations for best possible precision.

Shubhankar Poundrik
Shubhankar Poundrik 2020년 7월 2일
Hi Himanshu,
I understand that you are trying to store floating point numbers in variables and are not sure why the value in the variable is slightly different from what you entered.
This problem occurs because not all floating point numbers can be accurately represented in binary format. To store the float (floating point number) a certain number of bytes are used, and the binary representation of the float may have 1s beyond what can be stored in the available bytes.
Read for more detailed explanation :
Regards,
Shubhankar.
  댓글 수: 1
Walter Roberson
Walter Roberson 2020년 7월 2일
Statistically, the fraction of real numbers that can be stored as floating point, is zero. There are real numbers, but less than floating point numbers, and a finite non-zero number divided by an infinite quantity gives 0.

이 질문은 마감되었습니다.

제품

Community Treasure Hunt

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

Start Hunting!

Translated by