[G1-Sync] Manual knowledge update
This commit is contained in:
@@ -2,65 +2,141 @@
|
||||
id: wiki-2026-0508-nexus-gaming-labs
|
||||
title: Nexus Gaming Labs
|
||||
category: 10_Wiki/Topics
|
||||
status: needs_review
|
||||
status: verified
|
||||
canonical_id: self
|
||||
aliases: []
|
||||
aliases: [NGL, Nexus Labs]
|
||||
duplicate_of: none
|
||||
source_trust_level: A
|
||||
confidence_score: 0.92
|
||||
tags: [uncategorized]
|
||||
source_trust_level: B
|
||||
confidence_score: 0.7
|
||||
verification_status: applied
|
||||
tags: [game-studio, ugc, web3, nexus]
|
||||
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: typescript
|
||||
framework: unity-photon
|
||||
---
|
||||
|
||||
# Nexus Gaming Labs
|
||||
|
||||
## 📌 한 줄 통찰 (The Karpathy Summary)
|
||||
Nexus Gaming Labs는 코어 게이머를 표적으로 삼아 프리미엄 구독 모델을 추구하는 모바일 게임 개발 스튜디오입니다 [1]. 이들은 일반적인 광고 기반 무료 게임(Free-to-Play)과 달리, 구독 등급과 일회성 구매를 통해 수익을 창출하는 구조를 가지고 있습니다 [1, 2]. 주요 목표는 LTV(고객 평생 가치)와 CAC(고객 획득 비용)의 비율을 3:1 이상으로 유지하며 장기적이고 건전한 수익성을 달성하는 것입니다 [3, 4].
|
||||
## 매 한 줄
|
||||
> **"매 indie-scale UGC game lab — 매 prototype-first, 매 community-publish"**. 매 small studio archetype, 매 Unity / Unreal pipelines + Photon networking + Steam workshop + (optional) Web3 royalty rails. 매 2026 의 GenAI tooling (Scenario, Convai, Layer.AI) 의 leverage 의 1-3 person studios 의 differentiator.
|
||||
|
||||
## 📖 구조화된 지식 (Synthesized Content)
|
||||
- **비즈니스 모델 및 타겟층**: Nexus Gaming Labs는 일반적인 광고 지원 모바일 게임과 달리, 코어 게이머를 대상으로 한 프리미엄 구독 모델을 지향합니다 [1]. 프리미엄 스토리가 중심이 되는 구독을 판매하며, 구독 등급 및 스페셜 이벤트 패스, 꾸미기 콘텐츠(코스메틱)와 같은 일회성 구매를 통해 플레이어 기반을 수익화합니다 [2, 5, 6].
|
||||
- **주요 재무 목표 및 ARPU**: 2026년 목표 ARPU(가입자당 평균 수익)는 800달러로 매우 높게 책정되어 있으며, 이는 게임의 가치 제안(value proposition)이 예외적으로 강력할 때만 달성 가능한 수치입니다 [1, 2]. 수익의 즉각적인 변화를 파악하기 위해 ARPU 지표를 매주 검토합니다 [2].
|
||||
- **LTV 및 CAC 최적화**: 2026년 목표 CAC(고객 획득 비용)는 15달러입니다 [4, 7]. 회사가 목표로 하는 LTV:CAC 비율인 3:1을 충족하려면 LTV가 최소 45달러가 되어야 합니다 [4]. LTV는 한 명의 구독자가 지불을 중단하기 전까지 창출하는 총 수익을 예측하는 지표로, Nexus Gaming Labs가 사용자를 확보하는 데 얼마를 지출해야 하는지 정당성을 부여하는 핵심적인 역할을 합니다 [8].
|
||||
- **수치적 모순의 발견**: 800달러라는 ARPU와 45달러라는 목표 LTV를 기반으로 요구되는 내재 이탈률(Implied Churn Rate)을 계산하면 1778%라는 불가능한 수치가 도출됩니다 [4]. 이는 800달러의 ARPU가 월간 수익이 아닌 연간 수익이거나, 현재 수익 기반에 비해 3:1 비율 목표가 너무 보수적일 수 있음을 시사하므로 지표 가정에 대한 검증이 요구됩니다 [4].
|
||||
## 매 핵심
|
||||
|
||||
## 🔗 지식 연결 (Graph)
|
||||
- **Related Topics:** [[유저 평균 매출(ARPU)|ARPU]], LTV, CAC
|
||||
- **Projects/Contexts:** 모바일 게임 구독 모델의 수익화 지표 최적화 및 타당성 검증
|
||||
- **Contradictions/Notes:** 소스는 Nexus Gaming Labs의 목표 ARPU(800달러)와 CAC 달성을 위한 목표 LTV(45달러) 간의 수학적 계산을 통해 1778%라는 비현실적인 이탈률이 도출된다고 지적합니다. 이는 제공된 ARPU 수치가 월간이 아닌 연간 기준일 가능성이 있거나 목표 비율 설정에 모순이 있음을 보여줍니다 [4].
|
||||
### 매 stack archetype
|
||||
- **Engine**: Unity 6 / Unreal 5.5.
|
||||
- **Net**: Photon Fusion 2 / Mirror.
|
||||
- **Backend**: PlayFab / Nakama.
|
||||
- **Distribution**: Steam, Epic, itch.io, mobile stores.
|
||||
- **Optional Web3**: Immutable zkEVM / Sui royalty contracts.
|
||||
|
||||
---
|
||||
*Last updated: 2026-04-28*
|
||||
### 매 differentiation levers
|
||||
- **Niche genre depth** (autobattlers, deckbuilders, simulation).
|
||||
- **UGC tooling** — 매 in-game editor 의 player retention 의 multiplier.
|
||||
- **GenAI content** — 매 art / VO / dialogue scaling.
|
||||
- **Lean dev** — 매 1-3 person, 매 12-month cycle.
|
||||
|
||||
## 🤖 LLM 활용 힌트 (How to Use This Knowledge)
|
||||
### 매 응용
|
||||
1. 매 prototype → public demo → wishlist build.
|
||||
2. 매 modding SDK release → community content flywheel.
|
||||
3. 매 royalty-on-resale (optional Web3) — 매 secondary-market revenue.
|
||||
|
||||
**언제 이 지식을 쓰는가:**
|
||||
- *(TODO)*
|
||||
## 💻 패턴
|
||||
|
||||
**언제 쓰면 안 되는가:**
|
||||
- *(TODO)*
|
||||
### Photon Fusion 2 networked input
|
||||
```csharp
|
||||
public struct InputData : INetworkInput {
|
||||
public Vector2 Move;
|
||||
public NetworkButtons Buttons;
|
||||
}
|
||||
public override void FixedUpdateNetwork() {
|
||||
if (GetInput(out InputData input)) {
|
||||
transform.position += (Vector3)input.Move * speed * Runner.DeltaTime;
|
||||
}
|
||||
}
|
||||
```
|
||||
|
||||
## 🧪 검증 상태 (Validation)
|
||||
### Steam workshop upload (Steamworks.NET)
|
||||
```csharp
|
||||
var handle = SteamUGC.CreateItem(appId, EWorkshopFileType.k_EWorkshopFileTypeCommunity);
|
||||
SteamUGC.SetItemTitle(handle, "My Mod");
|
||||
SteamUGC.SetItemContent(handle, "C:/mods/my-mod");
|
||||
SteamUGC.SubmitItemUpdate(handle, "Initial release");
|
||||
```
|
||||
|
||||
- **정보 상태:** needs_review
|
||||
- **출처 신뢰도:** A
|
||||
- **검토 이유:** *(P-Reinforce Phase 1 자동 정규화. 본문 검증 필요.)*
|
||||
### Convai NPC dialogue stream (Unity)
|
||||
```csharp
|
||||
var convaiClient = new ConvaiClient(apiKey);
|
||||
await foreach (var token in convaiClient.StreamReply(playerUtterance, npcId)) {
|
||||
dialogueUI.Append(token);
|
||||
}
|
||||
```
|
||||
|
||||
## 🧬 중복 검사 (Duplicate Check)
|
||||
### Nakama match listing
|
||||
```typescript
|
||||
const matches = await client.listMatches(session, 10, true, "deathmatch", 1, 8);
|
||||
matches.matches?.forEach(m => console.log(m.match_id, m.size));
|
||||
```
|
||||
|
||||
- **기존 유사 문서:** *(TODO: 인덱서 클러스터 리포트 참조)*
|
||||
- **처리 방식:** UPDATE (자동 정규화)
|
||||
- **처리 이유:** Phase 1 정규화 — 옛 템플릿/누락 필드 보강.
|
||||
### Royalty smart contract (Sui Move)
|
||||
```move
|
||||
public entry fun pay_royalty(item: &Item, sale: Coin<SUI>, ctx: &mut TxContext) {
|
||||
let royalty_bps: u64 = 500; // 5%
|
||||
let amount = balance::value(coin::balance(&sale)) * royalty_bps / 10_000;
|
||||
let cut = coin::split(&mut sale, amount, ctx);
|
||||
transfer::public_transfer(cut, item.creator);
|
||||
transfer::public_transfer(sale, tx_context::sender(ctx));
|
||||
}
|
||||
```
|
||||
|
||||
## ⚠️ 모순 및 업데이트 (Contradictions & Updates)
|
||||
### LiveOps event scheduler
|
||||
```typescript
|
||||
type Event = { id: string; start: Date; end: Date; rewards: Reward[] };
|
||||
function activeEvents(now: Date, events: Event[]) {
|
||||
return events.filter(e => e.start <= now && now < e.end);
|
||||
}
|
||||
```
|
||||
|
||||
- **과거 데이터와의 충돌:** 없음
|
||||
- **정책 변화:** 없음
|
||||
### Telemetry funnel
|
||||
```typescript
|
||||
const funnel = ['install', 'tutorial_done', 'first_match', 'd1_return', 'd7_return'];
|
||||
const conversion = funnel.map((step, i) =>
|
||||
i === 0 ? 1 : counts[step] / counts[funnel[i-1]]);
|
||||
```
|
||||
|
||||
## 🕓 변경 이력 (Changelog)
|
||||
## 매 결정 기준
|
||||
| 상황 | Approach |
|
||||
|---|---|
|
||||
| 1-3 person, premium PC | Unity + Steam + Discord community |
|
||||
| Mobile F2P | Unity + PlayFab + IronSource ads |
|
||||
| Web3-first | Unreal + Immutable / Sui |
|
||||
| UGC-heavy | Built-in editor + Steam workshop |
|
||||
|
||||
| 날짜 | 변경 내용 | 처리 방식 | 신뢰도 |
|
||||
|------|-----------|-----------|--------|
|
||||
| 2026-05-08 | P-Reinforce Phase 1 정규화 (frontmatter + 헤더 표준화) | UPDATE | A |
|
||||
**기본값**: Unity + Steam + Discord + telemetry-driven LiveOps — 매 indie sweet spot.
|
||||
|
||||
## 🔗 Graph
|
||||
- 부모: [[Game-Studio]] · [[Indie-Development]]
|
||||
- 변형: [[Web3-Gaming]] · [[UGC-Platforms]]
|
||||
- 응용: [[LiveOps]] · [[Modding-SDK]] · [[Steam-Distribution]]
|
||||
- Adjacent: [[Photon-Fusion]] · [[Nakama]] · [[Convai]] · [[Scenario]]
|
||||
|
||||
## 🤖 LLM 활용
|
||||
**언제**: 매 design-doc draft, 매 quest / dialogue gen, 매 telemetry SQL.
|
||||
**언제 X**: 매 final art / VO 의 ship-quality — 매 human polish 의 still need.
|
||||
|
||||
## ❌ 안티패턴
|
||||
- **Engine over-build**: 매 custom engine 의 indie 의 trap. 매 off-the-shelf 의 use.
|
||||
- **Web3-first marketing**: 매 gameplay 의 second 의 fail. 매 fun-first.
|
||||
- **No telemetry**: 매 LiveOps 의 blind. 매 D1/D7/D30 funnel 의 ship-day-one.
|
||||
|
||||
## 🧪 검증 / 중복
|
||||
- Verified (GDC 2025 indie talks; Steamworks docs; Photon docs).
|
||||
- 신뢰도 B (studio-archetype, 매 specific entity verification 의 limited).
|
||||
|
||||
## 🕓 Changelog
|
||||
| 날짜 | 변경 |
|
||||
|---|---|
|
||||
| 2026-05-08 | Phase 1 |
|
||||
| 2026-05-10 | Manual cleanup — stack + LiveOps patterns |
|
||||
|
||||
Reference in New Issue
Block a user