34 lines
4.2 KiB
Markdown
34 lines
4.2 KiB
Markdown
---
|
|
id: P-REINFORCE-AUTO-DD4F11
|
|
category: "10_Wiki/💡 Topics/AI"
|
|
confidence_score: 0.90
|
|
tags: [auto-reinforced]
|
|
last_reinforced: 2026-04-20
|
|
github_commit: "[P-Reinforce] Continuous Worker - GPU"
|
|
---
|
|
|
|
# [[GPU|GPU]]
|
|
|
|
## 📌 한 줄 통찰 (The Karpathy Summary)
|
|
> GPU(Graphics Processing Unit)는 실시간 3D 그래픽 렌더링과 병렬 연산 처리에 최적화된 하드웨어 장치이다 [1]. 최신 GPU는 수천 개의 프로세싱 코어를 갖추고 있어 그래픽 렌더링뿐만 아니라 물리 시뮬레이션, AI 추론 등 범용적인 병렬 작업에 뛰어난 성능을 발휘한다 [2, 3]. 웹 환경에서는 WebGL 및 WebGPU와 같은 그래픽 API를 통해 제어되며, 셰이더(Shader) 프로그램을 하드웨어 수준에서 매우 빠른 속도로 실행하여 시각적 결과물을 만들어낸다 [1, 4].
|
|
|
|
## 📖 구조화된 지식 (Synthesized Content)
|
|
* **웹 그래픽 파이프라인에서의 역할:** GPU는 WebGL이나 WebGPU API를 통해 전달된 셰이더 프로그램을 실행하여 HTML5 브라우저의 화면(`<canvas>`)에 3D 장면을 렌더링한다 [1, 4]. 렌더링 속도를 극대화하기 위해서는 애플리케이션 코드가 실행되는 환경과 GPU 간의 컨텍스트 스위칭(Context Switching) 및 통신을 최소화해야 하며, 가급적 렌더링에 필요한 모든 데이터를 GPU 메모리에 한 번만 복사하는 것이 이상적이다 [5-8].
|
|
* **GPU 바운드(GPU Bound)와 CPU 병목 현상:** 성능 분석 시 렌더링 지연의 원인이 CPU인지 GPU인지 파악하는 것이 중요하다 [9, 10]. 복잡한 프래그먼트 셰이더 연산이나 과도한 드로우 콜(Draw Call)이 발생할 경우, CPU는 유휴 상태임에도 GPU가 지속적으로 작동하며 한계에 부딪히는 'GPU 바운드' 현상이 발생한다 [11]. 반대로, 단일 스레드로 명령을 전송하는 WebGL 아키텍처 하에서는 최신 GPU가 초당 수백만 개의 폴리곤을 처리할 수 있음에도 불구하고 CPU가 명령을 충분히 빨리 전달하지 못해 GPU가 유휴 상태로 대기하는 CPU 병목 현상이 발생하기도 한다 [2, 12].
|
|
* **컴퓨트 셰이더를 통한 범용 병렬 처리(GPGPU):** 과거 WebGL은 GPU의 사용을 그래픽 렌더링에만 국한시켰으나, WebGPU는 컴퓨트 셰이더(Compute Shaders)를 도입하여 GPU를 범용 병렬 프로세서로 변모시켰다 [2, 3]. GPU의 SIMT(Single-Instruction-Multiple-Thread) 아키텍처를 활용하면 수십만 개의 파티클 시스템, 유체 시뮬레이션, 데이터 정렬, 기계학습 기반의 거대 언어 모델(LLM) 추론 등의 방대한 연산을 CPU 개입 없이 GPU 내부에서 직접 병렬로 처리할 수 있다 [3, 13-15].
|
|
* **성능 및 전력 효율 극대화:** GPU 주도형(GPU-driven) 렌더링 방식을 도입하여 오클루전 컬링, 물리 시뮬레이션 등의 핵심 로직을 GPU로 옮기면 CPU와 GPU 간의 데이터 왕복 횟수 및 동기화 오버헤드를 크게 줄일 수 있다 [16, 17]. 이는 명령 생성에 따른 CPU 부하를 감소시켜 전력 소비와 발열을 낮추며, 특히 모바일 기기에서 열에 의한 스로틀링(Thermal Throttling)을 방지하여 일관된 프레임 속도와 렌더링 성능을 유지하도록 돕는다 [17-19].
|
|
|
|
## ⚠️ 모순 및 업데이트 (Contradictions & RL Update)
|
|
- **과거 데이터와의 충돌:** 자동화 엔진에 의해 매핑된 지식으로, 추후 정밀 검증 필요.
|
|
- **정책 변화:** AI 분야의 자동 자산화 수행.
|
|
|
|
## 🔗 지식 연결 (Graph)
|
|
- **Related Topics:** [[WebGL|WebGL]], [[WebGPU|WebGPU]], [[Compute Shader|Compute Shader]], CPU
|
|
- **Projects/Contexts:** WebSplatter, Three.js, [[CesiumJS|CesiumJS]]
|
|
- **Contradictions/Notes:** 과거 WebGL 생태계에서는 구조적 한계로 인해 물리 연산이나 정렬 작업을 CPU에서 처리해야 했고 이로 인해 GPU가 자주 유휴 상태(Idle)에 머무는 비효율이 존재했다. 그러나 WebGPU의 등장으로 컴퓨트 셰이더 기반의 연산이 가능해지면서, 렌더링과 연산 모두를 GPU에서 병렬 처리하여 GPU의 하드웨어 능력을 온전히 활용할 수 있게 되었다 [2, 3, 12, 20].
|
|
|
|
---
|
|
*Last updated: 2026-04-19*
|
|
|
|
---
|