[G1-Sync] Manual knowledge update
This commit is contained in:
@@ -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 4–8).
|
||||
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 5–10 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 |
|
||||
|
||||
**기본값**: 매 5–20 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 |
|
||||
|
||||
Reference in New Issue
Block a user