• SEARCH

    통합검색
세모계
    • Dark Mode
    • GNB Always Open
    • GNB Height Maximize
    • Color
    • Brightness
    • SINCE 2015.01.19.
    • 세모계 세모계
    •   SEARCH
    • 세상의 모든 계산기
      • 자유(질문) 게시판
      • 계산기 뉴스/정보
      • 수학, 과학, 공학 이야기
      • 세모계 : 공지 게시판
        • 구글 맞춤검색
    • TI
    • CASIO
    • HP
    • SHARP
    • 일반(쌀집) 계산기
    • 기타계산기
    • by OrangeDay
  • 세상의 모든 계산기 자유(질문) 게시판
    • 세상의 모든 계산기 자유(질문) 게시판 ()
    • (복잡한 다항식 수식에서) 계산기 내부 유효 자릿수에 따른 approx() 오차

    • Profile
      • 세상의모든계산기
      • 2025.10.27 - 13:28 2025.10.22 - 12:05 3103 6

    TI-nspire 기종에 대한 solve 질문글에 대해 답변을 하던 중 이상한 점을 발견하였습니다.

    https://allcalc.org/55823

     

    평소에는

    방정식의 해를 numeric 한 방식으로 solve 를 이용해 찾는 것보다,

    vs

    (소숫점을 없애서) exact 방식으로 참 값을 먼저 구하고 → 그 값에 대한 근사값 approx(참 값)

    을 구하는 것이 더 정확했습니다.

     

    그런데 이번에는 반대로 오차가 커지는 겁니다. 이 궁금증을 해결하기 위해 직접 분석을 진행해 보았습니다.

    image.png

    1. 분석 대상 수식

    분석에 사용된 수식은 다음과 같습니다. cos, sin의 단위는 모두 degree입니다.

    $$ \dfrac{120 \left( 150000 \left( \cos\left(\dfrac{7001}{5000}\right) \sqrt{2} - 2 \sin\left(\dfrac{217999}{5000}\right) \right) \cos\left(\dfrac{217999}{5000}\right) - 136342 \sin\left(\dfrac{217999}{5000}\right) \cos\left(\dfrac{7001}{5000}\right) - \left( 150000 \sin\left(\dfrac{7001}{5000}\right) \sin\left(\dfrac{217999}{5000}\right) - 68171 \right) \sqrt{2} \right)}{\sin\left(\dfrac{7001}{5000}\right) \left( 150000 \cos\left(\dfrac{7001}{5000}\right) \cos\left(\dfrac{217999}{5000}\right) - 150000 \sin\left(\dfrac{7001}{5000}\right) \sin\left(\dfrac{217999}{5000}\right) + 68171 \right)} $$

    ((120*(150000*(cos(((7001)/(5000)))*√(2)-2*sin(((217999)/(5000))))*cos(((217999)/(5000)))-136342*sin(((217999)/(5000)))*cos(((7001)/(5000)))-(150000*sin(((7001)/(5000)))*sin(((217999)/(5000)))-68171)*√(2)))/(sin(((7001)/(5000)))*(150000*cos(((7001)/(5000)))*cos(((217999)/(5000)))-150000*sin(((7001)/(5000)))*sin(((217999)/(5000)))+68171)))

    2. 가장 정확한 기준값은? (고정밀도 계산)

    오차를 측정하려면 가장 정확한 '참값'이 필요합니다. 일반적인 PC 계산 환경(64비트 float)의 한계를 넘어서기 위해, 파이썬의 mpmath 라이브러리를 사용하여 100자리의 정밀도로 기준값을 계산했습니다.

    기준값 (100자리 정밀도):
    73.04950705847862934420128091048894148771096960598761210206551516481655390211661403804814403351531886

    3. 최종 정밀도 분석표

    위 100자리 고정밀도 기준값을 바탕으로, 각기 다른 십진수 유효자릿수를 가진 가상의 계산기를 시뮬레이션하여, 오차를 측정한 결과입니다.

    유효자릿수
    시뮬레이션 계산 결과
    실제 오차 (vs 100자리 절대값, 일부 생략)
    6
    73.0496
    0.0000929415213705222166847666122236
    7
    73.05274
    0.00323294152137066489366610724034
    8
    73.049758
    0.00025094152137065247515544299319
    9
    73.0494926
    0.0000144584786293447601893855457378
    10
    73.04950392
    0.00000313847862934422482624283943565
    11
    73.049507264
    0.000000205521370655802788174857506077
    12
    73.0495070344
    0.0000000240786293442009088985191012186
    13
    73.04950705634
    0.00000000213862934420122992156882411472
    14
    73.049507058547
    6.8370655798718306374102620489e-11
    15
    73.0495070585241
    4.54706557987191402555162474671e-11
    16
    73.04950705847651
    2.11934420128089909820778774776e-12
    17
    73.049507058478403
    2.263442012809062555690176752e-13
    18
    73.0495070584786359
    6.55579871908965212938025673134e-15
    19
    73.04950705847863067
    1.32579871908948155385084562584e-15
    20
    73.049507058478629386
    4.17987190895119656392043225004e-17
    21
    73.049507058478629312
    3.22012809104888423825358781415e-17
    22
    73.04950705847862934452
    3.18719089511043124817045362596e-19
    23
    73.049507058478629344148
    5.32809104889360986718490925566e-20
    참고: 표준 64비트 float 계산
    - 계산 결과: 73.04950705847811
    - 실제 오차: 5.16135835013993051626500528352e-13

    4. 왜 이런 오차가 발생할까?

    컴퓨터의 숫자 저장 방식: 2진법의 한계

    가장 근본적인 원인은 컴퓨터가 숫자를 2진법으로 저장하는 데 있습니다. 우리가 사용하는 10진수 소수 중 상당수는 2진수로 변환하면 무한소수가 되어, 정해진 비트(bit) 안에 완벽하게 담지 못하고 근사치로 저장됩니다. 이 작은 근사 오차가 계산 과정에서 계속 누적되어 최종 결과에 영향을 미칩니다.

    누적 오차의 예시

    (1 / 3) * 3 을 유효자릿수 4자리 계산기로 계산하는 상황을 가정해 봅시다.

    1. 1 / 3 계산: 결과는 0.333333... 이지만, 4자리만 저장할 수 있으므로 0.3333으로 반올림됩니다. (첫 오차 발생)
    2. 0.3333 * 3 계산: 결과는 0.9999가 됩니다. 참값인 1.0과 미세한 차이가 생깁니다.

    복잡한 수식은 이런 과정이 수십, 수백 번 반복되는 것과 같으므로 작은 오차들이 모여 눈에 띄는 차이를 만들게 됩니다.

    문제가 된 처음의 수식 역시 계산기 입장에서 아래와 같은 수많은 연산을 거치며 오차가 누적 및 증폭되어 최종적으로 solve의 정상 범주를 벗어난 x값이 구해진 것이라고 분석할 수 있겠습니다.

    • 나눗셈 (Division): 12회
    • 사인 (sin): 7회
    • 코사인 (cos): 5회
    • 루트 (√): 2회
    • 곱셈 (Multiplication): 15회
    • 뺄셈 (Subtraction): 5회
    • 덧셈 (Addition): 1회

    결론

    일반적인 공학용 계산기(보통 10~14자리)의 정밀도는 대부분의 상황에서 충분히 신뢰할 만합니다. 하지만 이번 분석처럼 매우 복잡한 연산을 하거나, 과학/금융 분야에서 극도의 정밀도를 요구할 때는 표준 계산 환경의 한계를 인지하는 것이 중요합니다.

    이러한 한계를 극복하기 위해 파이썬의 mpmath와 같은 임의 정밀도 산술 라이브러리가 존재하며, 이를 통해 우리는 하드웨어의 제약을 넘어 원하는 만큼 정밀한 값을 얻을 수 있습니다.

    부록: 분석에 사용된 전체 Python 코드

    이 분석을 직접 재현해보고 싶으신 분들을 위해, 최종 분석에 사용된 전체 코드를 공유합니다. (mpmath 라이브러리 설치가 필요합니다: pip install mpmath)

    final_precision_analysis.py

    Attached file
    image.png 925.4KB 23final_precision_analysis.py 6.5KB 26
    이 게시물을..
    N
    0
    0
    • 세상의모든계산기 25
      세상의모든계산기

      계산기는 거들 뿐
      혹은
      계산기를 거들 뿐

    세상의모든계산기 님의 최근 글

    ban 설정 강화 2440 1 2026 05.09 정적분 구간에 미지수가 있고, solve 를 사용할 수 없을 때 그 값을 확인하려면? 1208 4 2026 04.10 높아질수록 좁아지는 시야에 대하여 - written by ChatGPT 7466 2026 02.12 내가 올해 몇살이더라? (내 나이 계산기) 6449 2026 02.11 AGI 자기 거버넌스 구조와 인간-AGI 관계 모델 (written by GEMINI & GPT) 7650 1 2026 01.30

    세상의모든계산기 님의 최근 댓글

    아 그렇네요. 감사합니다. ^^ 2026 04.28 정적분 구간에 미지수가 있고, solve 를 사용할 수 없을 때 그 값을 확인하려면? https://allcalc.org/57087 `SOLVE` 기능 내에 `∫(적분)` 기호를 사용할 수 없을 때 뉴튼-랩슨법을 직접 사용하는 방법 2026 04.15 뉴턴-랩슨 적분 방정식 시각화 v1.0 body { font-family: 'Pretendard', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif; display: flex; flex-direction: column; align-items: center; background: #f8f9fa; padding: 40px 20px; margin: 0; color: #333; } .container { background: white; padding: 40px; border-radius: 20px; box-shadow: 0 15px 35px rgba(0,0,0,0.08); max-width: 900px; width: 100%; } header { border-bottom: 2px solid #f1f3f4; margin-bottom: 30px; padding-bottom: 20px; } h1 { color: #1a73e8; margin: 0 0 10px 0; font-size: 1.8em; } p.subtitle { color: #5f6368; margin: 0; font-size: 1.1em; } .equation-box { background: #f1f3f4; padding: 15px; border-radius: 10px; text-align: center; margin-bottom: 30px; font-size: 1.3em; } canvas { border: 1px solid #e0e0e0; border-radius: 12px; background: #fff; width: 100%; height: auto; display: block; } .controls { margin-top: 30px; display: flex; gap: 15px; align-items: center; justify-content: center; flex-wrap: wrap; } button { padding: 12px 25px; border: none; border-radius: 8px; background: #1a73e8; color: white; cursor: pointer; font-weight: 600; font-size: 1em; transition: all 0.2s; box-shadow: 0 2px 5px rgba(26,115,232,0.3); } button:hover { background: #1557b0; transform: translateY(-1px); box-shadow: 0 4px 8px rgba(26,115,232,0.4); } button:active { transform: translateY(0); } button.secondary { background: #5f6368; box-shadow: 0 2px 5px rgba(0,0,0,0.2); } button.secondary:hover { background: #4a4e52; } .status-badge { background: #e8f0fe; color: #1967d2; padding: 8px 15px; border-radius: 20px; font-weight: bold; font-size: 0.9em; } .explanation { margin-top: 40px; padding: 25px; background: #fff8e1; border-left: 5px solid #ffc107; border-radius: 8px; line-height: 1.8; } .explanation h3 { margin-top: 0; color: #856404; } .math-symbol { font-family: 'Times New Roman', serif; font-style: italic; font-weight: bold; color: #d93025; } .code-snippet { background: #202124; color: #e8eaed; padding: 2px 6px; border-radius: 4px; font-family: monospace; } 📊 Newton-Raphson 적분 방정식 시뮬레이터 미분적분학의 기본 정리(FTC)를 이용한 수치해석 시각화 목표 방정식: ∫₀ᴬ (2√x) dx = 20 을 만족하는 A를 찾아라! 계산 시작 (A 추적) 초기화 현재 반복: 0회 💡 시각적 동작 원리 (Newton-Raphson & FTC) Step 1 (오차 측정): 현재 A까지 쌓인 파란색 면적이 목표치(20)와 얼마나 차이나는지 계산합니다. Step 2 (FTC의 마법): 면적의 변화율(미분)은 그 지점의 그래프 높이 f(A)와 같습니다. Step 3 (보정): 다음 A = 현재 A - (면적 오차 / 현재 높이) 공식을 사용하여 A를 이동시킵니다. 결론: 오차를 현재 높이로 나누면, 오차를 메우기 위해 필요한 가로 길이(ΔA)가 나옵니다. 이 과정을 반복하면 정답에 도달합니다! const canvas = document.getElementById('graphCanvas'); const ctx = canvas.getContext('2d'); const iterText = document.getElementById('iterText'); // 수학 설정 const targetArea = 20; const f = (x) => Math.sqrt(x) * 2; // 피적분 함수 f(x) = 2√x const F = (x) => (4/3) * Math.pow(x, 1.5); // 정적분 결과 F(x) = ∫ 2√x dx = 4/3 * x^(3/2) let A = 1.5; // 초기값 let iteration = 0; let animating = false; // 그래프 드로잉 설정 const scale = 50; const offsetX = 60; const offsetY = 380; function drawGrid() { ctx.strokeStyle = '#f1f3f4'; ctx.lineWidth = 1; ctx.beginPath(); for(let i=0; i 2026 04.11 참값 : A = ±2√5 근사값 : A≈±4.472135954999579392818347   2026 04.10 fx-570 ES 입력 결과 초기값 입력   반복 수식 입력    반복 결과       2026 04.10
    글쓴이의 서명작성글 감추기 

    댓글6

    • Profile 0
      세상의모든계산기
      2025.10.24 - 02:14 2025.10.22 - 12:45 #55934

      카시오 fx-570 ES, EX 로 계산하면?


      카시오도 (십진수) 14digits 한계이므로, 비슷한 값이 나올 것으로 예상됨. 

      다만, stack 및 길이 한계로 수식 전체를 그대로 입력할 수는 없음. 

       

      image.png image.png 

      image.png image.png 

       

      A,B,C,D 를 조합해 수식을 완성

      image.png

      image.png

      결과에서 73.049507 을 빼면 

      image.png 

      - fx-570 ES가 구한 결과값(Ans)은 

      73.0495070584404 (15digits) 로 최종 확인됨. 

      - TI-Nspire (14-digits) 보다 오차가 작음. 

      - 파이썬 시뮬레이션의 15-digits 결과(73.0495070585241)와 같지는 않음. 원인은 모르겠음. 

       

       

      fx-570_991EX_2025._10._24._오전_1_58_09.png

      ㄴ fx-570 EX 결과

      Attached file
      image.png 2.4KB 13 image.png 2.5KB 17 image.png 2.3KB 13 image.png 2.5KB 21 image.png 2.4KB 16 image.png 2.3KB 13 image.png 17.7KB 17 fx-570_991EX_2025._10._24._오전_1_58_09.png 9.7KB 16
      댓글
    • Profile 0
      세상의모든계산기
      2025.10.24 - 01:36 2025.10.22 - 13:11 #55944

      TI-nspire 에서 동일하게 a,b,c,d로 치환해서 계산


      image.png

       

      - 결과는 치환 없이 그냥 approx(전체식) 한 결과와 동일. 

      - 73.049507058547 (14-digits) 

      - 파이썬 시뮬레이션 14-digits 와 결과값이 같음. 

      Attached file
      image.png 2.4KB 17 image.png 11.8KB 15 image.png 123.4KB 14
      댓글
    • Profile 0
      세상의모든계산기
      2025.10.24 - 01:53 2025.10.22 - 22:49 #55957

      fx-9860 및 fx-CG 의 경우


      fx-9860GII SD 에서 위의 fx-570 과 같이 A,B,C,D 로 나눠서 계산하면

      image.png

       

      fx-CG에서 치환할 대상을 약간 바꿔서 분모→A, 분자→B 로 저장해 풀어보아도 

      image.png

       

      - 결과는 둘 다 같음.

      - 73.0495070585238 (15 digits)

      - fx-570ES와 같은 15-decimal-digits 정밀도인데, 왜 값이 다를까?

      - 파이썬 시뮬레이터상 15 digits 값과도 같지 않음. 

      Attached file
      image.png 10.0KB 17 image.png 4.7KB 17
      댓글
    • Profile 0
      세상의모든계산기
      2025.10.24 - 02:27 2025.10.24 - 02:06 #56017

      fx-570 CW 로 계산하면?


      fx-570_991CW_2025._10._24._오전_2_03_43.png fx-570_991CW_2025._10._24._오전_2_05_52.png

      fx-570_991CW_2025._10._24._오전_2_06_23.png fx-570_991CW_2025._10._24._오전_2_08_55.png

       

      - 최종 확인된 결과 값 = 73.049507058478629343538 (23-digits)

      - 오차 = 6.632809104889414877 × 10^-19

      꽤 정밀하게 나온건 맞는데, 시뮬레이션상의 22-digits 와 오차 수준이 비슷함. 왜 그런지는 모르겠음. 

      - 계산기중 정밀도가 높은 편인 HP Prime CAS모드와 비교해도 월등한 정밀도 값을 가짐. 

      Attached file
      fx-570_991CW_2025._10._24._오전_2_03_43.png 10.0KB 16 fx-570_991CW_2025._10._24._오전_2_05_52.png 9.9KB 15 fx-570_991CW_2025._10._24._오전_2_06_23.png 9.8KB 15 fx-570_991CW_2025._10._24._오전_2_08_55.png 9.8KB 18
      댓글
    • Profile 0
      세상의모든계산기
      2025.10.22 - 22:30 2025.10.22 - 22:30 #55954

      [공학용 계산기] 계산기 내부에서 사용하는 유효숫자 자릿수 Significant Digits


      https://allcalc.org/8848
       

      댓글
    • Profile 0
      세상의모든계산기
      2025.10.24 - 02:28 2025.10.23 - 22:29 #55996

      HP Prime 에서


      <Home>

      image.png

      73.0495070344 (12-decimal-digits) // python 시뮬레이션과 일치

       

      <CAS>

      image.png

      21자리까지 나와서 이상하다 싶었는데, 

      Ans- 에서 자릿수를 더 늘려서 빼보니, 뒷부분 숫자가 아예 바뀌어버림. 버그인가?

      (전) 73.0495070584718691243 (21-digits ????)

      (후) 73.0495070584718500814401 (24-digits ????)

      찾아보니 버그는 아니고, 

      CAS에서는 십진수가 아니라 2진수(bit) 단위로 처리한다고 함.

      Giac uses 48 bits mantissa from the 53 bits from IEEE double. The reason is that Giac stores CAS data (gen type) in 64 bits and 5 bits are used for the data type (24 types are available). We therefore loose 5 bits (the 5 low bits are reset to 0 when a double is retrieved from a gen).

      출처 : https://www.hpmuseum.org/cgi-bin/archv021.cgi?read=255657

      일단 오차를 놓고 보면 16-decimal-digits 수준으로 보임. 

      Attached file
      image.png 36.2KB 17 image.png 39.2KB 16 image.png 40.0KB 12 image.png 37.5KB 13
      댓글
    • 댓글 입력
    • 에디터 전환
    댓글 쓰기 에디터 사용하기 닫기
    • view_headline 목록
    • 14px
    • 목록
      view_headline
    6
    × CLOSE
    전체 일반 389 질문 507 웃김 2 팁 & 정보 16 퀴즈 2 리뷰 11 퍼옴 & 링크 6 공지 1
    기본 (0) 제목 날짜 수정 조회 댓글 추천 비추
    분류 정렬 검색
    등록된 글이 없습니다.
    • 글쓰기
    • 세상의 모든 계산기 자유(질문) 게시판
    • 세상의모든계산기
    • 사업자등록번호 703-91-02181
    • 세모계 all rights reserved.