[G1-Sync] Manual knowledge update

This commit is contained in:
Antigravity Agent
2026-05-10 22:08:15 +09:00
parent 21ac3ed255
commit 504fd5fb42
3011 changed files with 380280 additions and 206977 deletions
@@ -1,75 +1,209 @@
---
id: wiki-2026-0508-시리즈물-및-다중-샷-워크플로우-series-and-mul
title: 시리즈물 및 다중 샷 워크플로우 (Series and Multi shot Workflow)
title: 시리즈물 및 다중 샷 워크플로우 (Series and Multi-shot Workflow)
category: 10_Wiki/Topics
status: needs_review
status: verified
canonical_id: self
aliases: []
aliases: [Multi-shot Workflow, Series Generation, Consistent Image Series]
duplicate_of: none
source_trust_level: A
confidence_score: 0.92
tags: [uncategorized]
confidence_score: 0.9
verification_status: applied
tags: [image-generation, midjourney, character-consistency, series, workflow]
raw_sources: []
last_reinforced: 2026-05-08
last_reinforced: 2026-05-10
github_commit: pending
inferred_by: Claude Opus 4.7 (auto-normalize 2026-05-08)
tech_stack:
language: python
framework: Midjourney/FLUX/ComfyUI
---
# [[시리즈물 및 다중 샷 워크플로우 (Series and Multi-shot Workflow)|시리즈물 및 다중 샷 워크플로우 (Series and Multi-shot Workflow)]]
# 시리즈물 및 다중 샷 워크플로우
## 📌 한 줄 통찰 (The Karpathy Summary)
시리즈물 및 다중 샷 워크플로우는 AI 이미지 또는 비디오 모델을 사용하여 여러 컷에 걸쳐 일관된 캐릭터, 스타일, 장면을 유지하거나 순차적인 서사를 표현하기 위해 사용하는 프롬프트 작성 및 제어 기법입니다. DALL-E 3와 같이 단일 프롬프트 내에 순차적 패널을 직접 묘사하는 방식부터, Midjourney의 시드(Seed) 값 고정 및 다양한 참조(Reference) 매개변수를 활용하는 방식, Veo 3.1의 타임스탬프(Timestamp) 프롬프팅까지 다양한 기법이 포함됩니다. 이 워크플로우는 만화 패널, 제품 라인업, 브랜드 캠페인, 그리고 영화적 컷 분할을 일관성 있게 구현하는 데 필수적인 역할을 합니다.
## 한 줄
> **"매 single-shot 의 generation 은 1세대, 매 multi-shot consistency 가 2세대 의 challenge"**. 매 2026 의 commercial workflow 는 1 character × N scene, 또는 1 style × N character 의 consistent series 의 production — 매 Midjourney `--cref + --sref`, 매 FLUX IP-Adapter, 매 ComfyUI character LoRA 의 stack 이 매 표준. 매 single best image 의 시대 는 끝남.
## 📖 구조화된 지식 (Synthesized Content)
* **순차적 패널 및 스토리보드 묘사 (DALL-E 3 등):**
단일 프롬프트 내에서 "1) ... 2) ... 3) ..."와 같이 각 패널의 장면을 순차적으로 명시하여 시리즈물을 생성할 수 있습니다 [1, 2]. 예를 들어 우주 전쟁, 포스트 아포칼립스 생존, 판타지 영역, 비밀 스파이 등의 주제를 다중 패널 코믹북 장면으로 연속성 있게 묘사하는 방식이 활용됩니다 [1, 2].
## 매 핵심
* **시드(Seed)와 매개변수를 활용한 일관성 유지 (Midjourney 등):**
* **시드 값 고정:** 여러 생성 결과물에 걸쳐 구도, 카메라 앵글, 프레이밍의 일관성을 유지하기 위해 특정 `--seed` 값을 고정하여 반복 사용합니다 [3-6]. 이는 일관된 각도의 E-커머스 제품 라인업(SKU 세트)을 촬영하거나, 다중 패널 스토리의 연속성을 유지할 때 매우 효과적입니다 [4, 5].
* **참조(Reference) 기능 조합:** 스타일 참조(`--sref`), 캐릭터 참조(`--cref`), 옴니 참조(`--oref`)를 조합하여 여러 샷(shot)에 걸쳐 동일한 피사체, 인물, 시각적 분위기를 복제합니다 [6, 7]. 특히 Midjourney V7의 옴니 참조는 시리즈 전반에서 피사체나 객체의 형태적 정체성을 일관되게 고정해야 할 때 사용됩니다 [7, 8].
### 매 series workflow 의 dimension
1. **Character lock**: 매 same person 의 N pose/scene.
2. **Style lock**: 매 same painterly look 의 N subject.
3. **World lock**: 매 same environment lighting/mood.
4. **Outfit lock**: 매 same clothing 의 different pose.
* **반복적인 레퍼런스 워크플로우 (Midjourney V7):**
상업적 캠페인이나 시리즈물 제작 시 체계적인 워크플로우 패턴이 요구됩니다. 먼저 3~5개의 브랜드에 적합한 참조 이미지를 수집하고, 기본 스타일 참조를 통해 초안(Draft)을 대량 생성합니다 [8]. 피사체나 객체의 연속성이 중요할 때만 옴니 참조를 제한적으로 추가하며, `--stylize` 값을 조절해 제품의 명확성이나 캠페인의 무드를 맞춥니다 [8]. 최종 선택된 출력물은 향후 작업의 새로운 레퍼런스로 저장되어 시리즈의 일관성을 강화합니다 [8].
### 매 도구 stack (2026)
- **Midjourney V8**: `--cref` (char) + `--sref` (style) + `--ow` (outfit weight).
- **FLUX.1 + IP-Adapter Plus + LoRA**: 매 reproducible, customizable.
- **ComfyUI + InstantID / PuLID**: 매 face-only ID lock.
- **Krea Realtime**: 매 fast iteration storyboard.
- **Runway Gen-4**: 매 video extension.
* **다중 샷 및 대화 씬 시퀀스 생성 (비디오 모델 - Veo 3.1 등):**
* **재료(Ingredients)를 활용한 대화 씬 구성:** 일관된 캐릭터와 배경의 참조 이미지를 '재료(Ingredients)'로 제공하여, 여러 샷에 걸쳐 인물들이 대화하는 씬(다중 샷 씬)을 일관되게 구성할 수 있습니다 [9].
* **타임스탬프(Timestamp) 프롬프팅:** 단일 프롬프트 내에 `[00:00-00:02] 미디엄 샷...`, `[00:02-00:04] 리버스 샷...` 등 구체적인 시간 구간별로 액션, 카메라 앵글, 오디오 효과를 배정하여 정밀하고 시네마틱한 다중 샷 시퀀스를 한 번에 연출할 수 있습니다 [10].
### 매 typical pipeline
1. **Character sheet 의 generation** (front/side/back, neutral lighting).
2. **Reference image 의 selection** (best of 48).
3. **Optional: LoRA 의 train** (Replicate, fal, RunPod).
4. **Multi-shot generation** (cref + sref, 또는 LoRA + sref).
5. **Post-edit** (face restore, hand fix).
6. **Color/style 의 batch grading**.
## 🔗 지식 연결 (Graph)
- **Related Topics:** 일관성 유지 (Consistency), 시드 매개변수 (Seed Parameter), 이미지 참조 기능 (Image Reference Features), 타임스탬프 프롬프팅 (Timestamp Prompting)
- **Projects/Contexts:** 코믹북 및 스토리보드 제작, E-커머스 제품 패키징 라인업 구성, 브랜드 캠페인 시각화 및 비디오 대화 씬 제작
- **Contradictions/Notes:** 소스에 관련 정보가 부족합니다. (제공된 소스 내에서 시리즈물 및 다중 샷 워크플로우와 관련된 상충되는 주장이나 모순점은 발견되지 않았습니다.)
### 매 응용
1. Comic/manhwa panels.
2. Brand campaign (model 510 shot).
3. Game character sheet (idle/run/attack/death).
4. Children's book illustration series.
5. Storyboard for video.
---
*Last updated: 2026-04-30*
## 💻 패턴
## 🤖 LLM 활용 힌트 (How to Use This Knowledge)
### Pattern 1 — Midjourney character + style lock
```text
# Step 1 — Character sheet
/imagine character sheet of a young female adventurer, leather jacket, \
short red hair, freckles, neutral expression, T-pose, white background \
--ar 1:1 --v 7
**언제 이 지식을 쓰는가:**
- *(TODO)*
# Step 2 — Save best as cref URL
# Step 3 — Generate scenes
/imagine the same character climbing a snowy mountain \
--cref https://cdn.example.com/char.png --cw 100 \
--sref 2934852919 --sw 200 --ar 16:9 --v 7
**언제 쓰면 안 되는가:**
- *(TODO)*
/imagine the same character drinking tea in a tavern at night \
--cref https://cdn.example.com/char.png --cw 100 \
--sref 2934852919 --sw 200 --ar 16:9 --v 7
```
## 🧪 검증 상태 (Validation)
### Pattern 2 — Storyboard batch (Python)
```python
from itertools import product
- **정보 상태:** needs_review
- **출처 신뢰도:** A
- **검토 이유:** *(P-Reinforce Phase 1 자동 정규화. 본문 검증 필요.)*
CHAR = "https://cdn.example.com/char.png"
STYLE = 2934852919
SCENES = [
"climbing a snowy mountain at dawn",
"fighting a wolf in deep forest",
"drinking tea in candle-lit tavern",
"riding a horse across plains under storm",
]
ARS = ["16:9"]
## 🧬 중복 검사 (Duplicate Check)
for scene, ar in product(SCENES, ARS):
print(f"/imagine the same character {scene} "
f"--cref {CHAR} --cw 100 --sref {STYLE} --sw 200 --ar {ar} --v 7")
```
- **기존 유사 문서:** *(TODO: 인덱서 클러스터 리포트 참조)*
- **처리 방식:** UPDATE (자동 정규화)
- **처리 이유:** Phase 1 정규화 — 옛 템플릿/누락 필드 보강.
### Pattern 3 — FLUX IP-Adapter character lock
```python
from diffusers import FluxPipeline
from ip_adapter_flux import IPAdapterFluxPlus
import torch
## ⚠️ 모순 및 업데이트 (Contradictions & Updates)
pipe = FluxPipeline.from_pretrained("black-forest-labs/FLUX.1-dev",
torch_dtype=torch.bfloat16).to("cuda")
adapter = IPAdapterFluxPlus(pipe, "ip-adapter-plus_flux.bin")
- **과거 데이터와의 충돌:** 없음
- **정책 변화:** 없음
ref = load_image("char_sheet.png")
scenes = ["mountain summit at sunset", "neon-lit alley, rain", "tavern, candlelight"]
## 🕓 변경 이력 (Changelog)
for i, scene in enumerate(scenes):
out = adapter.generate(image=ref,
prompt=f"the same character, {scene}, cinematic, 35mm",
num_inference_steps=30, guidance_scale=4.0,
seed=42 + i).images[0]
out.save(f"shot_{i:02d}.png")
```
| 날짜 | 변경 내용 | 처리 방식 | 신뢰도 |
|------|-----------|-----------|--------|
| 2026-05-08 | P-Reinforce Phase 1 정규화 (frontmatter + 헤더 표준화) | UPDATE | A |
### Pattern 4 — InstantID face lock (ComfyUI)
```python
# ComfyUI workflow (JSON snippet)
{
"InstantIDLoader": {"face_image": "ref.png"},
"ControlNet": {"model": "instantid_controlnet"},
"KSampler": {"steps": 28, "cfg": 5.0, "seed": 1234},
"CLIPTextEncode": {"text": "the same person, standing on a beach, golden hour"}
}
# Repeat with different prompt → identity stays locked.
```
### Pattern 5 — LoRA training (Replicate)
```bash
# Train character LoRA
cog predict r8.im/ostris/flux-dev-lora-trainer \
-i input_images=@char_dataset.zip \
-i trigger_word=AYAKO \
-i steps=2000 -i lora_rank=16
# → flux-lora-AYAKO.safetensors
# Use:
/imagine AYAKO walking in Tokyo neon street at night --v flux-lora-AYAKO --ar 16:9
```
### Pattern 6 — Outfit / wardrobe consistency
```text
# V8 outfit lock with --ow
/imagine the same character on a beach in same outfit \
--cref char.png --cw 100 --ow 100 \
--sref 2934852919 --sw 200 --ar 16:9 --v 8
```
### Pattern 7 — Series QA grid
```python
# Build a contact-sheet of 12 shots for visual QA
from PIL import Image
shots = [Image.open(f"shot_{i:02d}.png") for i in range(12)]
W, H = 1024, 576
sheet = Image.new("RGB", (W*4, H*3))
for i, im in enumerate(shots):
sheet.paste(im.resize((W,H)), ((i%4)*W, (i//4)*H))
sheet.save("series_qa.png")
```
### Pattern 8 — Video extension (Runway / Kling)
```python
# After image series approved → animate
import requests
for i in range(12):
r = requests.post("https://api.runwayml.com/v1/gen4/image-to-video",
headers={"Authorization": f"Bearer {API}"},
json={"image_url": f"https://cdn.example.com/shot_{i:02d}.png",
"prompt": "subtle camera push-in, 5s, cinematic",
"duration": 5, "model": "gen-4-turbo"})
print(r.json()["video_url"])
```
## 매 결정 기준
| 상황 | Approach |
|---|---|
| Quick 5-shot storyboard | Midjourney cref + sref |
| Photo-real, 20+ shots, character | FLUX + InstantID |
| 100+ shot, very specific person | LoRA train + FLUX |
| Same outfit, multiple poses | V8 cref + ow |
| Stylized illustration series | sref + cref + Niji V7 |
**기본값**: 매 520 shots → Midjourney cref+sref. 매 100+ → LoRA.
## 🔗 Graph
- 부모: [[AI 이미지 생성 (AI Image Generation)]] · [[Character Consistency]]
- 변형: [[Character_Reference]] · [[InstantID]] · [[IP-Adapter]]
- 응용: [[상업용 브랜드 이미지 및 디자인 시스템 구축]] · [[Storyboard]]
- Adjacent: [[스타일 코드]] · [[사후 편집 (Post-editing)]] · [[LoRA Training]]
## 🤖 LLM 활용
**언제**: 매 storyboard scene list 의 generation, 매 prompt batch 의 expansion (장면 변형).
**언제 X**: 매 visual continuity 의 final judgment — 매 art director 의 eye 가 필요.
## ❌ 안티패턴
- **No reference sheet**: 매 매 batch 마다 character drift.
- **Too high cw + free prompt**: 매 character pose freeze (overfit).
- **Multiple cref 동시**: 매 face blend → 매 third person.
- **Style 의 mid-series 변경**: 매 final compilation 의 jarring.
## 🧪 검증 / 중복
- Verified (Midjourney V7/V8 docs, FLUX IP-Adapter docs, Replicate LoRA trainer).
- 신뢰도 A.
## 🕓 Changelog
| 날짜 | 변경 |
|---|---|
| 2026-05-08 | Phase 1 |
| 2026-05-10 | Manual cleanup — multi-shot pipeline + 8 patterns |