- CASIO 570
[fx-570] 복소수 1차 연립방정식 해법 (feat. 반복법 Gauss-Seidel Method)
1. EQN 및 행렬 기능의 한계
[fx-570ES PLUS] 계산기에는 연립방정식의 해를 구하는 EQN 기능이 있습니다만, 계수 및 해의 범위는 실수로 한정됩니다.
행렬(Matrix) 모드에서도 element에는 실수만 입력시킬 수 있습니다. 게다가 최대 행렬은 3×3 까지만 가능...ㅠㅠ
따라서, [fx-570ES (Plus)]에서 계산기 내장기능만으로는 계수나 해가 복소수인 연립방정식을 풀 수가 없습니다.
역행렬 공식을 (암기) 활용하여 구하는 방법은 있습니다.
https://allcalc.org/43763
2. 반복법 (Gauss-Seidel Method)
하지만 반복법인 가우스-자이델 법을 이용하면 복소수의 해를 찾을 수(도) 있습니다. 실수에 대한 연립방정식을 반복법으로 풀었던 것과 동일합니다.
[fx-570] Iteration, Gauss-Seidel 가우스-자이델 법으로 연립방정식 풀기
원래의 수식을 미지수에 대해 각각 손으로 정리할 필요가 있어서, 번거롭습니다.
실수일 때에 비해 입력실수가 더 잦은 편이므로, 시간낭비를 하기 싫으시면 매우 꼼꼼하게 확인하시는게 좋습니다.
수렴해야 답이 나오는데, 오히려 발산하는 경우도 있습니다.
발산하는 경우 실수에서와 마찬가지로, 정리하는 변수의 순서를 바꾸면 답이 나올 수도 있습니다.
(행렬로 봤을 때) 대각행렬의 위치에 해당하는 계수의 크기(Abs)가 (행에서) 가장 큰 값이 되도록 행의 배치를 바꾸시면 됩니다.
결국은 매우 비실용적인 방법이므로 (입력이 수월한)
실험삼아 상급 계산기에서나 한번쯤 해볼만한 방법입니다.
3. 예시
다음 두 식을 만족시키는 복소수 v1 과 v2를 구해보겠습니다.
(0.2+0.2*i)v1 - (0.1*i)v2 = 1
−(0.1*i)v1 + (0.1-0.1*i)v2 = 0.5*i
- 윗 식은 v1에 대하여, 아랫 식은 v2에 대하여 손으로 정리합니다.
((1+0.1*i*v2)/(0.2+0.2*i))→v1
((0.5*i+0.1*i*v1)/(0.1-0.1*i))→v2
- 복소수 모드로 이동합니다.
【MODE】 【2】
- V1을 A로, V2를 B로 치환하고
A=ㅁㅁㅁ:B=△△△ 꼴로 계산기에 입력합니다.

- 【CALC】 버튼을 눌러서 계산을 시작합니다.
ㄴ
【CALC】 대신 【=】 를 누르면 Error 가 납니다.
- B? (B값을 묻는 화면)에서 B의 초기값을 입력합니다.
【0】 【=】
- 【=】 반복하여 누릅니다.
A, B 값이 특정 값에 수렴할 때까지 반복합니다.

- 위에서 식을 입력할 때 두 식을 나누어 입력할 수도 있습니다.
(더 복잡하고 번거롭기 때문에 굳이 그럴 이유는 없습니다)
- 복소수 계산 모드로 이동합니다.
【MODE】 【2】
- A의 초기값을 입력합니다.
【0】 【SHIFT】 【RCL】 【(-)】
ㄴ B의 초기값은 입력할 필요가 없습니다.
- A, B 로 대치하여 그대로 계산기에 입력하고 【=】 계산합니다.

앞서 계산한 두개의 식을 번갈아가면서 교대로 실행해야 하므로
【▲】 【=】 【▲】 【=】
【▲】 【=】 【▲】 【=】
... 를 반복하여 입력합니다.
언제까지?
결과가 어떤 수에 수렴할 때까지...
18회를 반복하니 (=36회의 계산) 답이 나옵니다.

세상의모든계산기 님의 최근 댓글
뉴턴-랩슨 적분 방정식 시각화 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 파이썬 코드 검증 결과 초기값: 5.0 반복 1회차: 4.5000000000 반복 2회차: 4.4722222222 반복 3회차: 4.4721359558 반복 4회차: 4.4721359550 반복 5회차: 4.4721359550 초기값: 10.0 반복 1회차: 6.0000000000 반복 2회차: 4.6666666667 반복 3회차: 4.4761904762 반복 4회차: 4.4721377913 반복 5회차: 4.4721359550 2026 04.10 감사합니다. 주말 잘 보내세요. 2026 03.06