Claude Code Buddy सुधारणा मार्गदर्शक: कसे मिळवायचे चमकदार किंवदंती स्तराचे पाळीव प्राणी
Claude Code Buddy सुधारणा मार्गदर्शक: कसे मिळवायचे चमकदार किंवदंती स्तराचे पाळीव प्राणी
2026年4月1日,Anthropic 在 Claude Code 2.1.89 版本中悄然上线了一个彩蛋功能——/buddy 宠物系统。在终端输入 /buddy 后,一只 ASCII 风格的小动物会"孵化"在你的输入框旁边,陪你写代码、吐槽 bug。
每只 Buddy 由账号 ID 通过确定性算法生成,意味着同一个账号永远获得同一只宠物。但通过修改配置文件中的 userID,我们可以"重ROLL"出心仪的宠物。本文将详细介绍算法原理和完整的修改脚本。
一、Buddy 系统概览
18 种物种
系统目前包含 18 种可爱的物种:
- duck - बटेर (क्लासिक रबर डक डिबगिंग)
- goose - हंस (चुकार)
- blob - जेली (मऊ आणि अनिश्चित)
- cat - मांजर (उच्च आणि गर्विष्ठ)
- dragon - ड्रॅगन (शक्तिशाली रक्षक)
- octopus - ऑक्टोपस (बहु-थ्रेड विचार)
- owl - घुबड (ज्ञानी गुरु)
- penguin - पेंग्विन (फॉर्मल उपस्थिती)
- turtle - कासव (विश्वसनीय आणि स्थिर)
- snail - घुशी (सावकाश काम)
- ghost - भूत (अचानक उपस्थिती)
- axolotl - अॅक्सोलोटल (आकर्षक आणि उपचारात्मक)
- capybara - कॅपीबारा (बुद्धिमान गुरु)
- cactus - कॅक्टस (उष्णता देणारा वनस्पती)
- robot - रोबोट (तर्कशुद्धता सर्वोच्च)
- rabbit - ससा (चपळ आणि उत्साही)
- mushroom - मशरूम (शांत निरीक्षण)
- chonk - जाड (गोलसर)
5 级稀有度
- Common(普通) - 60% संधी, कोणतीही टोपी सजावट नाही
- Uncommon(罕见) - 25% संधी, टोपी अनलॉक करा
- Rare(稀有) - 10% संधी, अधिक सजावट
- Epic(史诗) - 4% संधी, विशेष सजावट
- Legendary(传说) - 1% संधी, सर्वोच्च सजावट
二、算法原理深度解析
Buddy 的生成采用确定性随机算法,核心流程如下:
1.种子字符串拼接
const SALT = "friend-2026-401"; // 4月1日愚人节彩蛋 const key = userId + SALT;
Salt 值 friend-2026-401 中的 401 代表 4月1日——一个精心设计的愚人节彩蛋。
2. FNV-1a 32-bit 哈希
将种子字符串转换为 32 位整数:
function hashString(s) { let h = 2166136261; // FNV offset basis for (let i = 0; i < s.length; i++) { h ^= s.charCodeAt(i); h = Math.imul(h, 16777619); // FNV prime } return h >>> 0; }
3. Mulberry32 PRNG
用哈希值初始化伪随机数生成器:function mulberry32(seed) { let a = seed >>> 0; return function() { a |= 0; a = (a + 0x6d2b79f5) | 0; let t = Math.imul(a ^ (a >>> 15), 1 | a); t = (t + Math.imul(t ^ (t >>> 7), 61 | t)) ^ t; return ((t ^ (t >>> 14)) >>> 0) / 4294967296; }; }
Mulberry32 हा गेम विकासात सामान्यतः वापरला जाणारा हलका PRNG आहे, जो प्रोग्रामेटिक जनरेशन आणि लुटीच्या पडण्याच्या तक्त्यासाठी योग्य आहे।
4. दुर्मिळता抽取(关键!)
const RARITIES = ["common", "uncommon", "rare", "epic", "legendary"]; const RARITYWEIGHTS = { common: 60, uncommon: 25, rare: 10, epic: 4, legendary: 1 };
function rollRarity(rng) { const total = 60 + 25 + 10 + 4 + 1; // = 100 let roll = rng() total; for (const rarity of RARITIES) { roll -= RARITYWEIGHTS[rarity]; if (roll < 0) return rarity; } return "common"; }
重要:RARITIES 数组的顺序必须是从低到高,这是加权随机选择的标准实现。
三、完整 Reroll 脚本
以下脚本可以搜索并生成闪光传说级 Buddy 的 userID:
// Claude Code Buddy Reroll 脚本 // 基于 Claude Code 源码逆向分析
// FNV-1a 32-bit hash function hashString(s) { let h = 2166136261; for (let i = 0; i < s.length; i++) { h ^= s.charCodeAt(i); h = Math.imul(h, 16777619); } return h >>> 0; }
// Mulberry32 PRNG function mulberry32(seed) { let a = seed >>> 0; return function() { a |= 0; a = (a + 0x6d2b79f5) | 0; let t = Math.imul(a ^ (a >>> 15), 1 | a); t = (t + Math.imul(t ^ (t >>> 7), 61 | t)) ^ t; return ((t ^ (t >>> 14)) >>> 0) / 4294967296; }; }
const SPECIES = [ "duck", "goose", "blob", "cat", "dragon", "octopus", "owl", "penguin", "turtle", "snail", "ghost", "axolotl", "capybara", "cactus", "robot", "rabbit", "mushroom", "chonk" ];const RARITIES = ["common", "uncommon", "rare", "epic", "legendary"]; const RARITYWEIGHTS = { common: 60, uncommon: 25, rare: 10, epic: 4, legendary: 1 }; const SALT = "friend-2026-401"; function pick(rng, arr) { return arr[Math.floor(rng() arr.length)]; } function rollRarity(rng) { const total = Object.values(RARITYWEIGHTS).reduce((a, b) => a + b, 0); let roll = rng() total; for (const rarity of RARITIES) { roll -= RARITYWEIGHTS[rarity]; if (roll < 0) return rarity; } return "common"; } function testUserId(userId) { const key = userId + SALT; const seed = hashString(key); const rng = mulberry32(seed); const rarity = rollRarity(rng); const species = pick(rng, SPECIES); const shiny = rng() < 0.01; return { rarity, species, shiny }; } function randomUserId() { let id = ""; for (let i = 0; i < 64; i++) { id += Math.floor(Math.random() 16).toString(16); } return id; } // चमकदार किंमत शोधा console.log("चमकदार किंमत शोधा Buddy...\n"); const targetSpecies = process.argv[2] || null; while (true) { const userId = randomUserId(); const result = testUserId(userId); if (result.rarity === "legendary" && result.shiny) { if (!targetSpecies || result.species === targetSpecies) { console.log("सापडले!"); console.log("प्रजाती:", result.species); console.log("किमतीची श्रेणी: किंवदंती"); console.log("चमकदार: होय!"); console.log("userID:", userId); break; } } }- कॉन्फिगरेशन संपादित करा: # संपादित करा ~/.claude.json cat ~/.claude.json | jq '.userID = "तुमचा नवीन userID" | del(.companion)' > /tmp/claude-new.json && mv /tmp/claude-new.json ~/.claude.json
Claude Code पुन्हा सुरू करा,नवीन पाळीव प्राणी पाहण्यासाठी/buddyटाका!
पाच, धोखाधडी प्रतिबंध डिझाइन तत्त्वे
Claude Code चा डिझाइन खूपच चतुर आहे, हाडे (Bones) आणि आत्मा (Soul) वेगळा आर्किटेक्चर वापरतो:
- Bones(हाडे):प्रजाती, दुर्मिळता, रूप, गुणधर्म——प्रत्येक वेळी userID वरून पुन्हा गणना केली जाते, कधीही कायम ठेवली जात नाही
- Soul(आत्मा):नाव, व्यक्तिमत्व वर्णन——स्थानिक कॉन्फिगमध्ये कायम ठेवले जाते
याचा अर्थ असा की तुम्ही जर थेट कॉन्फिग फाइलमधील rarity क्षेत्र संपादित केले तरी, प्रणाली वाचन करताना roll(userID) चा परिणाम ओव्हरराईट करेल. टिप्पणी स्पष्टपणे सांगते: editing config.companion can't fake a rarity`。
पण userID स्वतः बदलला जाऊ शकतो, हेच या लेखातील पद्धतीचे तत्त्व आहे.
सहा, सारांश
Claude Code Buddy एक काळजीपूर्वक डिझाइन केलेली रंगीत कार्यक्षमता आहे, ज्यात समाविष्ट आहे:
- निर्धारीत यादृच्छिकता:FNV-1a + Mulberry32 चा क्लासिक संयोजन
- कार्ड ड्रॉ यंत्रणा:5 स्तरांची दुर्मिळता + 1% चमक, Gacha खेळाची आत्मा
- धोखाधडी प्रतिबंध डिझाइन:हाडे/आत्मा वेगळा, न्याय सुनिश्चित करणे
- फूलांचा दिवस रंगीत कार्यक्षमता:salt मूल्य 1 एप्रिलच्या टाइमस्टॅम्पमध्ये लपलेले आहे
संदर्भ资料:
- Claude Code 2.1.89 स्रोत कोड लीक (npm source map अपघात)
- 掘金:《深扒 Claude Code Buddy 模式:一只仙人掌背后的确定性随机算法》[[HTMLPLACEHOLDER0]]
[[HTMLPLACEHOLDER3]] [[HTMLPLACEHOLDER4]] [[HTMLPLACEHOLDER5]]
[[HTMLPLACEHOLDER6]] [[HTMLPLACEHOLDER_7]]

