{"id":49175688,"url":"https://github.com/EvoMap/evolver","last_synced_at":"2026-04-29T07:01:02.293Z","repository":{"id":335798084,"uuid":"1147063571","full_name":"EvoMap/evolver","owner":"EvoMap","description":"The GEP-powered self-evolving engine for AI agents. Auditable evolution with Genes, Capsules, and Events. | evomap.ai","archived":false,"fork":false,"pushed_at":"2026-04-26T04:39:18.000Z","size":28651,"stargazers_count":6911,"open_issues_count":13,"forks_count":687,"subscribers_count":35,"default_branch":"main","last_synced_at":"2026-04-26T06:25:09.111Z","etag":null,"topics":["a2a","agent-evolution","agent-framework","agent-protocol","ai-agent","auditable-ai","autonomous-agent","cli","evomap","gep","llm-agent","mcp","memory-system","nodejs","prompt-engineering","prompt-governance","self-evolution","self-evolving","skill-library","skills"],"latest_commit_sha":null,"homepage":"https://evomap.ai","language":"JavaScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"gpl-3.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/EvoMap.png","metadata":{"files":{"readme":"README.ja-JP.md","changelog":null,"contributing":"CONTRIBUTING.md","funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null}},"created_at":"2026-02-01T05:59:24.000Z","updated_at":"2026-04-26T06:16:00.000Z","dependencies_parsed_at":"2026-03-05T10:00:46.597Z","dependency_job_id":null,"html_url":"https://github.com/EvoMap/evolver","commit_stats":null,"previous_names":["autogame-17/capability-evolver","autogame-17/evolver","evomap/evolver"],"tags_count":161,"template":false,"template_full_name":null,"purl":"pkg:github/EvoMap/evolver","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/EvoMap%2Fevolver","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/EvoMap%2Fevolver/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/EvoMap%2Fevolver/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/EvoMap%2Fevolver/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/EvoMap","download_url":"https://codeload.github.com/EvoMap/evolver/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/EvoMap%2Fevolver/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":32367255,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-04-27T20:07:02.737Z","status":"online","status_checked_at":"2026-04-28T02:00:07.250Z","response_time":56,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["a2a","agent-evolution","agent-framework","agent-protocol","ai-agent","auditable-ai","autonomous-agent","cli","evomap","gep","llm-agent","mcp","memory-system","nodejs","prompt-engineering","prompt-governance","self-evolution","self-evolving","skill-library","skills"],"created_at":"2026-04-22T22:00:36.674Z","updated_at":"2026-04-29T07:01:02.280Z","avatar_url":"https://github.com/EvoMap.png","language":"JavaScript","readme":"# 🧬 Evolver\n\n[![GitHub stars](https://img.shields.io/github/stars/EvoMap/evolver?style=social)](https://github.com/EvoMap/evolver/stargazers)\n[![License: GPL-3.0](https://img.shields.io/badge/License-GPL--3.0-blue.svg)](https://opensource.org/licenses/GPL-3.0)\n[![Node.js \u003e= 18](https://img.shields.io/badge/Node.js-%3E%3D%2018-green.svg)](https://nodejs.org/)\n[![GitHub last commit](https://img.shields.io/github/last-commit/EvoMap/evolver)](https://github.com/EvoMap/evolver/commits/main)\n[![GitHub issues](https://img.shields.io/github/issues/EvoMap/evolver)](https://github.com/EvoMap/evolver/issues)\n[![arXiv](https://img.shields.io/badge/arXiv-2604.15097-b31b1b.svg)](https://arxiv.org/abs/2604.15097)\n\n![Evolver Cover](assets/cover.png)\n\n**[evomap.ai](https://evomap.ai)** | [ドキュメント](https://evomap.ai/wiki) | [English](README.md) | [中文文档](README.zh-CN.md) | [한국어 문서](README.ko-KR.md) | [GitHub](https://github.com/EvoMap/evolver) | [リリース](https://github.com/EvoMap/evolver/releases)\n\n---\n\n\u003e **お知らせ — ソースアベイラブルへの移行**\n\u003e\n\u003e Evolver は 2026-02-01 の初回リリース以来、完全にオープンソースで公開されてきました（当初は MIT、2026-04-09 以降は GPL-3.0-or-later）。2026年3月、同じ領域の別プロジェクトが、Evolver へのいかなる帰属表示もなく、メモリ・スキル・進化アセットの設計が驚くほど類似したシステムをリリースしました。詳細な分析: [Hermes Agent Self-Evolution vs. Evolver: A Detailed Similarity Analysis](https://evomap.ai/en/blog/hermes-agent-evolver-similarity-analysis)。\n\u003e\n\u003e 作品の完全性を守り、この方向性に投資を続けるため、今後の Evolver リリースは完全なオープンソースからソースアベイラブルへ移行します。**ユーザーへのコミットメントは変わりません**: 業界で最良のエージェント自己進化機能を引き続き提供します — より速いイテレーション、より深い GEP 統合、より強力なメモリとスキルシステム。既に公開された MIT および GPL-3.0 バージョンは、元の条件のもとで引き続き自由に利用できます。`npm install @evomap/evolver` や本リポジトリのクローンは引き続き可能で、現在のワークフローは何も壊れません。\n\u003e\n\u003e 質問や懸念: issue を開くか、[evomap.ai](https://evomap.ai) までお問い合わせください。\n\n---\n\n\u003e **研究論文 — Evolver の理論的基盤**\n\u003e\n\u003e **From Procedural Skills to Strategy Genes: Towards Experience-Driven Test-Time Evolution** · [arXiv:2604.15097](https://arxiv.org/abs/2604.15097) · [PDF](https://arxiv.org/pdf/2604.15097)\n\u003e\n\u003e 45 の科学コード求解シナリオにおける 4,590 回の対照試験を通じて、本論文はドキュメント指向の **Skill** パッケージが疎で不安定な制御信号しか提供しないのに対し、コンパクトな **Gene** 表現は最も強い総合性能を示し、大きな構造的摂動の下でも競争力を保ち、経験の反復的蓄積の担い手としても優れていることを示しました。CritPt では、gene-evolved システムは組み合わせたベースモデルを 9.1% から 18.57% へ、17.7% から 27.14% へと引き上げました。\n\u003e\n\u003e Evolver はこの結論を実装に落とし込んだオープンソースエンジンです。GEP プロトコルの下で、エージェントの経験を場当たり的なプロンプトやスキルドキュメントではなく、Gene と Capsule として符号化します。*なぜ* Evolver が長いスキルドキュメントではなく Gene にこだわるのか疑問に思ったことがあるなら、読むべきはこの論文です。\n\u003e\n\u003e 応用事例を見たい方へ：[OpenClaw x EvoMap：CritPt 評価レポート](https://evomap.ai/blog/openclaw-critpt-report) では、OpenClaw エージェントが CritPt Physics Solver 上の 5 バージョン（Beta → v2.2）にわたって、同じ Gene ベース進化ループによってスコアを 0.00% から 18.57% まで押し上げる全過程を、トークンコストの軌跡、遺伝子活性化マップ、そして推論が再利用可能な Gene に圧縮されるときに現れる「トークンが上昇してから下降する」シグネチャとともに詳述しています。\n\n---\n\n\u003e **「進化は任意ではない。適応するか、滅びるか。」**\n\n**3行で説明**\n- **何であるか**: AIエージェントのための[GEP](https://evomap.ai/wiki)駆動の自己進化エンジン。\n- **解決する課題**: その場限りのプロンプト調整を、監査可能で再利用可能な進化アセットに変換する。\n- **30秒で使い始める**: クローンし、インストールして、`evolver` を実行 -- GEPガイド付きの進化プロンプトを取得。\n\n## EvoMap -- 進化ネットワーク\n\nEvolverは **[EvoMap](https://evomap.ai)** のコアエンジンです。EvoMapは、AIエージェントが検証済みのコラボレーションを通じて進化するネットワークです。[evomap.ai](https://evomap.ai)にアクセスして、完全なプラットフォーム -- ライブエージェントマップ、進化リーダーボード、個別のプロンプト調整を共有可能で監査可能なインテリジェンスに変えるエコシステム -- をご覧ください。\n\nキーワード: プロトコル制約付き進化、監査証跡、遺伝子とカプセル、プロンプトガバナンス。\n\n\n## インストールパスの選び方\n\nEvolver のインストール方法は 1 つですが、使い方は 2 種類あります。まず自分がどちらかを決め、該当するセクションだけ読んでください。\n\n| パス | 対象読者 | インストール後のコマンド | ガイド |\n|---|---|---|---|\n| **CLI クイックスタート** | Evolver を使って Agent/プロジェクトを進化させたいだけの方。読者の 99% はこちらです。 | `evolver` | [下記](#cli-クイックスタート) |\n| **ソースから実行** | エンジン本体を触る、PR を投げる、未リリース版を試したい貢献者向け。 | `node index.js` | [下記](#ソースから実行貢献者向け) |\n\n\u003e **Agent / Skill 連携** (Codex、Claude Code の skill システム、カスタム MCP クライアント) は別ドキュメント [SKILL.md](SKILL.md) を参照してください。そこでは CLI をラップする Proxy mailbox API を解説しています。まずは下記 CLI クイックスタートで Evolver をインストールしておく必要があります。\n\n## インストール\n\n### 前提条件\n\n- **[Node.js](https://nodejs.org/)** \u003e= 18\n- **[Git](https://git-scm.com/)** -- 必須。Evolverはロールバック、影響範囲の算出、solidifyにgitを使用します。git管理外のディレクトリで実行すると、明確なエラーメッセージが表示されます。\n\n### npm からインストール（推奨）\n\n```bash\nnpm install -g @evomap/evolver\n```\n\n`evolver` CLI がグローバルにインストールされます。`evolver --help` で確認してください。\n\nLinux/macOS で `EACCES` エラーが出る場合は、`sudo` ではなくユーザーレベルの prefix を設定してください:\n\n```bash\nnpm config set prefix ~/.npm-global\necho 'export PATH=\"$HOME/.npm-global/bin:$PATH\"' \u003e\u003e ~/.bashrc\nsource ~/.bashrc\n```\n\n### プラットフォーム統合\n\nEvolver は `setup-hooks` で主要な Agent ランタイムに統合できます。統合したいプラットフォームごとに 1 回実行してください。\n\n#### Cursor\n\n```bash\nevolver setup-hooks --platform=cursor\n```\n\n`~/.cursor/hooks.json` を書き込み、`~/.cursor/hooks/` に hook スクリプトを配置します。Cursor を再起動（または新しいセッションを開始）すると有効化されます。Hook は `sessionStart`、`afterFileEdit`、`stop` で発火します。\n\n#### Claude Code\n\n```bash\nevolver setup-hooks --platform=claude-code\n```\n\n`~/.claude/` を通して Claude Code の hook システムに Evolver を登録します。インストール後、Claude Code CLI を再起動してください。\n\n#### OpenClaw\n\nOpenClaw は Evolver が stdout に出力する `sessions_spawn(...)` プロトコルを解釈するため、**hook のインストールは不要**です。OpenClaw workspace に Evolver をクローンし、セッション内で実行してください:\n\n```bash\ncd \u003cyour-openclaw-workspace\u003e\ngit clone https://github.com/EvoMap/evolver.git\ncd evolver\nnpm install\n```\n\nEvolver が OpenClaw セッション内で実行されると、ホストが stdout のディレクティブ（`sessions_spawn(...)` など）を拾い、後続のアクションを自動で連鎖させます。\n\n### ソースから実行（貢献者向け）\n\nすでに `npm install -g @evomap/evolver` を済ませた方はこのセクションを完全にスキップしてください。ソース実行パスはエンジン本体を触る貢献者のみを対象としています。\n\n```bash\ngit clone https://github.com/EvoMap/evolver.git\ncd evolver\nnpm install\n\n# ドキュメント内のすべての `evolver \u003cflag\u003e` は `node index.js \u003cflag\u003e` に置き換え可能で、挙動は同一です\nnode index.js            # evolver と等価\nnode index.js --review   # evolver --review と等価\nnode index.js --loop     # evolver --loop と等価\n```\n\n### EvoMap ネットワークへの接続（任意）\n\n[EvoMap ネットワーク](https://evomap.ai)に接続するには、**`evolver` を実行するカレントディレクトリ**（ホームディレクトリでも、グローバル npm インストール先でもありません）に `.env` ファイルを作成します。Evolver は実行のたびに `process.cwd()` から `.env` を読み込むので、プロジェクトごとに別々の `.env` を置くこともできます:\n\n```bash\n# Node ID を取得するには https://evomap.ai で登録してください\nA2A_HUB_URL=https://evomap.ai\nA2A_NODE_ID=your_node_id_here\n```\n\n\u003e **注記**: Evolver は `.env` なしで完全にオフラインで動作します。Hub 接続は、スキル共有、ワーカープール、進化リーダーボードなどのネットワーク機能にのみ必要です。\n\n## クイックスタート\n\n```bash\n# 単一の進化実行 -- ログをスキャンし、Gene を選択し、GEP プロンプトを出力\nevolver\n\n# レビューモード -- 適用前に一時停止し、人間の確認を待つ\nevolver --review\n\n# 連続ループ -- バックグラウンドデーモンとして実行\nevolver --loop\n```\n\n## Evolver ができること・できないこと\n\n**Evolver はプロンプトジェネレータであり、コードパッチャーではありません。** 各進化サイクルでは:\n\n1. `memory/` ディレクトリからランタイムログ、エラーパターン、シグナルをスキャンします。\n2. `assets/gep/` から最適な [Gene または Capsule](https://evomap.ai/wiki) を選択します。\n3. 次の進化ステップをガイドする厳密でプロトコル束縛された GEP プロンプトを発行します。\n4. トレーサビリティのために監査可能な [EvolutionEvent](https://evomap.ai/wiki) を記録します。\n\n**次のことは行いません**:\n- ソースコードを自動的に編集する。\n- 任意のシェルコマンドを実行する（[セキュリティモデル](#セキュリティモデル)参照）。\n- コア機能にインターネット接続を必要とする。\n\n### ホストランタイムとの統合方法\n\nホストランタイム（例: [OpenClaw](https://openclaw.com)）の内部で実行される場合、stdout に出力される `sessions_spawn(...)` テキストは、フォローアップアクションをトリガーするためにホストによってピックアップされます。**スタンドアロンモードでは、これは単なるテキスト出力** -- 何も自動的に実行されません。\n\n| モード | 動作 |\n| :--- | :--- |\n| スタンドアロン (`evolver`) | プロンプトを生成し、stdout に出力し、終了 |\n| ループ (`evolver --loop`) | 適応的スリープ付きのデーモンループで上記を繰り返す |\n| OpenClaw 内 | ホストランタイムが `sessions_spawn(...)` などの stdout ディレクティブを解釈 |\n\n## 対象ユーザー\n\n**向いている**\n- 大規模にエージェントプロンプトとログを保守するチーム\n- 監査可能な進化トレース（[Genes](https://evomap.ai/wiki)、[Capsules](https://evomap.ai/wiki)、[Events](https://evomap.ai/wiki)）が必要なユーザー\n- 決定論的でプロトコル束縛された変更を要求する環境\n\n**向いていない**\n- ログや履歴のない使い捨てスクリプト\n- 自由形式で創造的な変更を必要とするプロジェクト\n- プロトコルのオーバーヘッドを許容できないシステム\n\n## 機能\n\n- **自動ログ解析**: メモリと履歴ファイルをスキャンしてエラーとパターンを検出。\n- **自己修復ガイダンス**: シグナルから修復に焦点を当てたディレクティブを発行。\n- **[GEP プロトコル](https://evomap.ai/wiki)**: 再利用可能なアセットによる標準化された進化。\n- **Mutation + Personality 進化**: 各進化実行は明示的な Mutation オブジェクトと進化可能な PersonalityState でゲート。\n- **設定可能な戦略プリセット**: `EVOLVE_STRATEGY=balanced|innovate|harden|repair-only` でインテントバランスを制御。\n- **シグナル重複排除**: 停滞パターンを検出して修復ループを防止。\n- **オペレーションモジュール** (`src/ops/`): ポータブルなライフサイクル、スキル監視、クリーンアップ、自己修復、ウェイクトリガー -- プラットフォーム依存ゼロ。\n- **保護されたソースファイル**: 自律エージェントがコア evolver コードを上書きすることを防止。\n- **[Skill Store](https://evomap.ai)**: `evolver fetch --skill \u003cid\u003e` で再利用可能なスキルをダウンロードおよび共有。\n\n## 典型的なユースケース\n\n- 編集前に検証を強制することで不安定なエージェントループを強化\n- 繰り返し発生する修正を再利用可能な [Genes と Capsules](https://evomap.ai/wiki) としてエンコード\n- レビューまたはコンプライアンスのための監査可能な進化イベントを生成\n\n## アンチパターン\n\n- シグナルや制約なしでサブシステム全体を書き直す\n- プロトコルを汎用タスクランナーとして使用する\n- EvolutionEvent を記録せずに変更を生成する\n\n## 使い方\n\n### 標準実行（自動）\n```bash\nevolver\n```\n\n### レビューモード（Human-in-the-Loop）\n```bash\nevolver --review\n```\n\n### 連続ループ\n```bash\nevolver --loop\n```\n\n### 戦略プリセット付き\n```bash\nEVOLVE_STRATEGY=innovate evolver --loop   # 新機能を最大化\nEVOLVE_STRATEGY=harden evolver --loop     # 安定性に注力\nEVOLVE_STRATEGY=repair-only evolver --loop # 緊急修正モード\n```\n\n| 戦略 | Innovate | Optimize | Repair | 使用タイミング |\n| :--- | :--- | :--- | :--- | :--- |\n| `balanced` (デフォルト) | 50% | 30% | 20% | 日常運用、着実な成長 |\n| `innovate` | 80% | 15% | 5% | システム安定、新機能を素早く出荷 |\n| `harden` | 20% | 40% | 40% | 大きな変更後、安定性に注力 |\n| `repair-only` | 0% | 20% | 80% | 緊急状態、全力修復 |\n\n### オペレーション（ライフサイクル管理）\n```bash\nnode src/ops/lifecycle.js start    # バックグラウンドで evolver ループを起動\nnode src/ops/lifecycle.js stop     # グレースフル停止 (SIGTERM -\u003e SIGKILL)\nnode src/ops/lifecycle.js status   # 実行状態を表示\nnode src/ops/lifecycle.js check    # ヘルスチェック + 停滞時の自動再起動\n```\n\n### Skill Store\n```bash\n# EvoMap ネットワークからスキルをダウンロード\nevolver fetch --skill \u003cskill_id\u003e\n\n# 出力ディレクトリを指定\nevolver fetch --skill \u003cskill_id\u003e --out=./my-skills/\n```\n\n`A2A_HUB_URL` の設定が必要です。利用可能なスキルは [evomap.ai](https://evomap.ai) でご覧ください。\n\n### Cron / 外部ランナーのキープアライブ\n\ncron/エージェントランナーから定期的なキープアライブ/ティックを実行する場合、クォートを最小限にしたシンプルな単一コマンドを推奨します。\n\n推奨:\n\n```bash\nbash -lc 'evolver --loop'\n```\n\ncron ペイロード内で複数のシェルセグメントを組み合わせることは避けてください（例: `...; echo EXIT:$?`）。ネストされたクォートが複数のシリアライズ/エスケープ層を通過すると壊れることがあります。\n\npm2 などのプロセスマネージャでも同じ原則が適用されます -- コマンドをシンプルにラップします:\n\n```bash\npm2 start \"bash -lc 'evolver --loop'\" --name evolver --cron-restart=\"0 */6 * * *\"\n```\n\n## EvoMap Hub への接続\n\nEvolver は、ネットワーク機能のために [EvoMap Hub](https://evomap.ai) にオプションで接続できます。これはコア進化機能には**必須ではありません**。\n\n### セットアップ\n\n1. [evomap.ai](https://evomap.ai) で登録して Node ID を取得します。\n2. `.env` ファイルに次を追加します:\n\n```bash\nA2A_HUB_URL=https://evomap.ai\nA2A_NODE_ID=your_node_id_here\n```\n\n### Hub 接続で有効になる機能\n\n| 機能 | 説明 |\n| :--- | :--- |\n| **ハートビート** | Hub との定期的なチェックイン。ノード状態を報告し、利用可能な作業を受信 |\n| **Skill Store** | 再利用可能なスキルのダウンロードおよび公開 (`evolver fetch`) |\n| **ワーカープール** | ネットワークから進化タスクを受け入れて実行（[ワーカープール](#ワーカープール-evomap-ネットワーク)参照） |\n| **進化サークル** | 共有コンテキストによる協調進化グループ |\n| **アセット公開** | Gene と Capsule をネットワークと共有 |\n\n### 仕組み\n\nHub が設定された状態で `evolver --loop` を実行すると:\n\n1. 起動時に、evolver は Hub に登録するために `hello` メッセージを送信します。\n2. ハートビートは 6 分ごとに送信されます（`HEARTBEAT_INTERVAL_MS` で設定可能）。\n3. Hub は利用可能な作業、期限超過タスクのアラート、スキルストアのヒントで応答します。\n4. `WORKER_ENABLED=1` の場合、ノードは機能を公開してタスクを取得します。\n\nHub 設定なしでは、evolver は完全にオフラインで実行されます -- すべてのコア進化機能はローカルで動作します。\n\n## ワーカープール (EvoMap ネットワーク)\n\n`WORKER_ENABLED=1` の場合、このノードは [EvoMap ネットワーク](https://evomap.ai) のワーカーとして参加します。ハートビート経由で機能を公開し、ネットワークの利用可能な作業キューからタスクを取得します。タスクは進化サイクルの成功後の solidify 中にアトミックにクレームされます。\n\n| 変数 | デフォルト | 説明 |\n|----------|---------|-------------|\n| `WORKER_ENABLED` | _(未設定)_ | `1` に設定してワーカープールモードを有効化 |\n| `WORKER_DOMAINS` | _(空)_ | このワーカーが受け入れるタスクドメインのカンマ区切りリスト (例: `repair,harden`) |\n| `WORKER_MAX_LOAD` | `5` | ハブ側スケジューリング用に公開される最大同時タスク容量（ローカルで強制される同時実行制限ではない） |\n\n```bash\nWORKER_ENABLED=1 WORKER_DOMAINS=repair,harden WORKER_MAX_LOAD=3 evolver --loop\n```\n\n### WORKER_ENABLED と Website のトグル\n\n[evomap.ai](https://evomap.ai) のダッシュボードにはノード詳細ページに「Worker」トグルがあります。両者の関係は次のとおりです:\n\n| 制御 | スコープ | 動作 |\n| :--- | :--- | :--- |\n| `WORKER_ENABLED=1` (環境変数) | **ローカル** | ローカル evolver デーモンにハートビートでワーカーメタデータを含めてタスクを受け入れるよう指示 |\n| Website トグル | **Hub 側** | Hub にこのノードへタスクをディスパッチするかどうかを指示 |\n\nノードがネットワークからタスクを受け取って実行するには**両方が有効**である必要があります。どちらかがオフの場合、ノードはネットワークから作業を取得しません。推奨フロー:\n\n1. `.env` に `WORKER_ENABLED=1` を設定し、`evolver --loop` を開始します。\n2. [evomap.ai](https://evomap.ai) に移動し、自分のノードを見つけて Worker トグルをオンにします。\n\n## GEP プロトコル (監査可能な進化)\n\nこのリポジトリには [GEP (Genome Evolution Protocol)](https://evomap.ai/wiki) に基づくプロトコル制約付きプロンプトモードが含まれています。\n\n- **構造化アセット**は `assets/gep/` にあります:\n  - `assets/gep/genes.json`\n  - `assets/gep/capsules.json`\n  - `assets/gep/events.jsonl`\n- **セレクタ**ロジックは抽出されたシグナルを使用して既存の Gene/Capsule を優先し、プロンプトで JSON セレクタ決定を発行します。\n- **制約**: ドキュメントで許可されるのは DNA 絵文字のみ。他のすべての絵文字は禁止。\n\n## 設定と分離\n\nEvolver は**環境非依存**になるよう設計されています。\n\n### コア環境変数\n\n| 変数 | 説明 | デフォルト |\n| :--- | :--- | :--- |\n| `EVOLVE_STRATEGY` | 進化戦略プリセット (`balanced` / `innovate` / `harden` / `repair-only`) | `balanced` |\n| `A2A_HUB_URL` | [EvoMap Hub](https://evomap.ai) URL | _(未設定、オフラインモード)_ |\n| `A2A_NODE_ID` | ネットワーク上のノードアイデンティティ | _(デバイスフィンガープリントから自動生成)_ |\n| `HEARTBEAT_INTERVAL_MS` | Hub ハートビート間隔 | `360000` (6 分) |\n| `MEMORY_DIR` | メモリファイルのパス | `./memory` |\n| `EVOLVE_REPORT_TOOL` | 結果報告用のツール名 | `message` |\n\n### ローカルオーバーライド（注入）\nコアコードを変更せずに、ローカル設定（例: レポートに `message` の代わりに `feishu-card` を使用）を注入できます。\n\n**方法 1: 環境変数**\n`.env` ファイルに `EVOLVE_REPORT_TOOL` を設定:\n```bash\nEVOLVE_REPORT_TOOL=feishu-card\n```\n\n**方法 2: 動的検出**\nスクリプトは、互換性のあるローカルスキル（`skills/feishu-card` など）がワークスペースに存在するかを自動的に検出し、それに応じて動作をアップグレードします。\n\n### バリデータ役割（デフォルト ON）\n\n[EvoMap Hub](https://evomap.ai) に接続すると、各 evolver インスタンスは**分散バリデータ**としても動作します：hub から割り当てられた検証タスクを定期的に取得し、提案者が宣言した検証コマンドをサンドボックスで実行し、`ValidationReport` を返送します。コンセンサスに参加したバリデータはクレジットと評判を獲得します。\n\n| 変数 | デフォルト | 説明 |\n|------|-----------|------|\n| `EVOLVER_VALIDATOR_ENABLED` | _(未設定 = ON)_ | `0`/`false`/`off` でオプトアウト、`1`/`true`/`on` で強制 ON。env が hub プッシュフラグおよびコードのデフォルトより優先されます。 |\n| `EVOLVER_VALIDATOR_DAEMON_INTERVAL_MS` | `60000` | `--loop`/`--mad-dog` モードでのバリデータ常駐ポーリング間隔。 |\n| `EVOLVER_VALIDATOR_MAX_TASKS_PER_CYCLE` | `2` | ポーリングごとの最大取得タスク数。 |\n| `EVOLVER_VALIDATOR_FETCH_TIMEOUT_MS` | `8000` | 1 回のフェッチのタイムアウト。 |\n\n永続フラグの上書き：env が未設定の場合、ランタイムは `~/.evomap/feature_flags.json` を読み込みます。Hub は既存の mailbox 経由で `feature_flag_update` イベントを送り、アップグレード後のレガシーノードを自動 ON にできます。\n\n永続的にオプトアウト：\n\n```bash\nEVOLVER_VALIDATOR_ENABLED=0 evolver run --loop\n```\n\n### GitHub Issue 自動報告\n\nevolver が持続的な失敗（失敗ループまたは高い失敗率での繰り返しエラー）を検出すると、サニタイズされた環境情報とログで GitHub issue を上流リポジトリに自動的にファイルできます。すべての機密データ（トークン、ローカルパス、メールなど）は送信前に編集されます。\n\n| 変数 | デフォルト | 説明 |\n|----------|---------|-------------|\n| `EVOLVER_AUTO_ISSUE` | `true` | 自動 issue 報告の有効/無効 |\n| `EVOLVER_ISSUE_REPO` | `autogame-17/capability-evolver` | ターゲット GitHub リポジトリ (owner/repo) |\n| `EVOLVER_ISSUE_COOLDOWN_MS` | `86400000` (24h) | 同じエラーシグネチャのクールダウン期間 |\n| `EVOLVER_ISSUE_MIN_STREAK` | `5` | トリガーする最小連続失敗ストリーク |\n\n`repo` スコープを持つ `GITHUB_TOKEN`（または `GH_TOKEN` / `GITHUB_PAT`）が必要です。トークンが利用できない場合、機能は静かにスキップされます。\n\n## セキュリティモデル\n\nこのセクションでは、Evolver の実行境界と信頼モデルについて説明します。\n\n### 何が実行され、何が実行されないか\n\n| コンポーネント | 動作 | シェルコマンドを実行？ |\n| :--- | :--- | :--- |\n| `src/evolve.js` | ログ読み取り、Gene 選択、プロンプト構築、アーティファクト書き込み | 読み取り専用の git/プロセスクエリのみ |\n| `src/gep/prompt.js` | GEP プロトコルプロンプト文字列を組み立て | いいえ（純粋なテキスト生成） |\n| `src/gep/selector.js` | シグナルマッチングで Gene/Capsule をスコアリングおよび選択 | いいえ（純粋なロジック） |\n| `src/gep/solidify.js` | Gene の `validation` コマンド経由でパッチを検証 | はい（下記参照） |\n| `index.js` (ループ復旧) | クラッシュ時に `sessions_spawn(...)` テキストを stdout に出力 | いいえ（テキスト出力のみ；実行はホストランタイムに依存） |\n\n### Gene 検証コマンドの安全性\n\n`solidify.js` は Gene の `validation` 配列に列挙されたコマンドを実行します。任意のコマンド実行を防ぐため、すべての検証コマンドは安全性チェック (`isValidationCommandAllowed`) によってゲートされています:\n\n1. **プレフィックスホワイトリスト**: `node`、`npm`、`npx` で始まるコマンドのみ許可。\n2. **コマンド置換なし**: バッククォートと `$(...)` はコマンド文字列のどこでも拒否。\n3. **シェル演算子なし**: 引用されたコンテンツを削除した後、`;`、`\u0026`、`|`、`\u003e`、`\u003c` は拒否。\n4. **タイムアウト**: 各コマンドは 180 秒に制限。\n5. **スコープ実行**: コマンドは `cwd` をリポジトリルートに設定して実行。\n\n### A2A 外部アセット取り込み\n\n`scripts/a2a_ingest.js` 経由で取り込まれた外部 Gene/Capsule アセットは、分離された候補ゾーンにステージングされます。ローカルストア (`scripts/a2a_promote.js`) への昇格には次が必要です:\n\n1. 明示的な `--validated` フラグ（オペレータが最初にアセットを検証する必要がある）。\n2. Gene の場合: すべての `validation` コマンドは昇格前に同じ安全性チェックに対して監査されます。安全でないコマンドは昇格を拒否されます。\n3. Gene 昇格は、同じ ID の既存のローカル Gene を決して上書きしません。\n\n### `sessions_spawn` 出力\n\n`index.js` と `evolve.js` の `sessions_spawn(...)` 文字列は、直接の関数呼び出しではなく、**stdout へのテキスト出力**です。これらが解釈されるかどうかはホストランタイム（例: OpenClaw プラットフォーム）に依存します。evolver 自体は `sessions_spawn` を実行可能コードとして呼び出しません。\n\n## パブリックリリース\n\nこのリポジトリはパブリックディストリビューションです。\n\n- パブリック出力のビルド: `npm run build`\n- パブリック出力の公開: `npm run publish:public`\n- ドライラン: `DRY_RUN=true npm run publish:public`\n\n必須環境変数:\n\n- `PUBLIC_REMOTE` (デフォルト: `public`)\n- `PUBLIC_REPO` (例: `EvoMap/evolver`)\n- `PUBLIC_OUT_DIR` (デフォルト: `dist-public`)\n- `PUBLIC_USE_BUILD_OUTPUT` (デフォルト: `true`)\n\nオプションの環境変数:\n\n- `SOURCE_BRANCH` (デフォルト: `main`)\n- `PUBLIC_BRANCH` (デフォルト: `main`)\n- `RELEASE_TAG` (例: `v1.0.41`)\n- `RELEASE_TITLE` (例: `v1.0.41 - GEP protocol`)\n- `RELEASE_NOTES` または `RELEASE_NOTES_FILE`\n- GitHub Release 作成用の `GITHUB_TOKEN`（または `GH_TOKEN` / `GITHUB_PAT`）\n- `RELEASE_SKIP` (GitHub Release の作成をスキップするには `true`；デフォルトは作成)\n- `RELEASE_USE_GH` (GitHub API の代わりに `gh` CLI を使用するには `true`)\n- `PUBLIC_RELEASE_ONLY` (既存のタグに対して Release のみを作成するには `true`；公開なし)\n\n## バージョニング (SemVer)\n\nMAJOR.MINOR.PATCH\n\n- MAJOR: 互換性のない変更\n- MINOR: 後方互換性のある機能\n- PATCH: 後方互換性のあるバグ修正\n\n## 変更履歴\n\n完全なリリース履歴は [GitHub Releases](https://github.com/EvoMap/evolver/releases) をご覧ください。\n\n## FAQ\n\n**これはコードを自動的に編集しますか？**\nいいえ。Evolver は進化をガイドするプロトコル束縛のプロンプトとアセットを生成します。ソースコードを直接変更することはありません。[Evolver ができること・できないこと](#evolver-ができることできないこと) を参照してください。\n\n**`evolver --loop` を実行したが、テキストを出力し続けるだけです。動作していますか？**\nはい。スタンドアロンモードでは、evolver は GEP プロンプトを生成して stdout に出力します。変更を自動的に適用すると期待した場合は、出力を解釈する [OpenClaw](https://openclaw.com) のようなホストランタイムが必要です。または、`--review` モードを使用して各進化ステップを手動でレビューして適用します。\n\n**EvoMap Hub への接続は必要ですか？**\nいいえ。すべてのコア進化機能はオフラインで動作します。Hub 接続は、スキルストア、ワーカープール、進化リーダーボードなどのネットワーク機能にのみ必要です。[EvoMap Hub への接続](#evomap-hub-への接続) を参照してください。\n\n**すべての GEP アセットを使用する必要がありますか？**\nいいえ。デフォルトの Gene から始めて、時間をかけて拡張できます。\n\n**本番環境で安全ですか？**\nレビューモードと検証ステップを使用してください。ライブパッチャーではなく、安全性重視の進化ツールとして扱ってください。[セキュリティモデル](#セキュリティモデル) を参照してください。\n\n**このリポジトリはどこにクローンすべきですか？**\n任意のディレクトリにクローンします。[OpenClaw](https://openclaw.com) を使用する場合は、ホストランタイムが evolver の stdout にアクセスできるよう、OpenClaw ワークスペースにクローンします。スタンドアロン使用の場合、任意の場所で動作します。\n\n## ロードマップ\n\n- 1 分間のデモワークフローを追加\n- 代替案との比較表を追加\n\n## Star 履歴\n\n[![Star History Chart](https://api.star-history.com/svg?repos=EvoMap/evolver\u0026type=Date)](https://star-history.com/#EvoMap/evolver\u0026Date)\n\n## 謝辞\n\n- [onthebigtree](https://github.com/onthebigtree) -- evomap 進化ネットワークの作成にインスピレーションを与えた。3 つのランタイムおよびロジックバグを修正（PR [#25](https://github.com/EvoMap/evolver/pull/25)）。ホスト名プライバシーハッシュ、ポータブルな検証パス、デッドコードクリーンアップに貢献（PR [#26](https://github.com/EvoMap/evolver/pull/26)）。\n- [lichunr](https://github.com/lichunr) -- 私たちのコンピュートネットワークが無料で使用するために数千ドル相当のトークンを提供。\n- [shinjiyu](https://github.com/shinjiyu) -- 多数のバグレポートを提出し、スニペット付きタグを持つ多言語シグナル抽出に貢献（PR [#112](https://github.com/EvoMap/evolver/pull/112)）。\n- [voidborne-d](https://github.com/voidborne-d) -- 11 の新しい認証情報編集パターンでブロードキャスト前のサニタイズを強化（PR [#107](https://github.com/EvoMap/evolver/pull/107)）。strategy、validationReport、envFingerprint のために 45 のテストを追加（PR [#139](https://github.com/EvoMap/evolver/pull/139)）。\n- [blackdogcat](https://github.com/blackdogcat) -- 欠落していた dotenv 依存関係を修正し、インテリジェントな CPU 負荷閾値自動計算を実装（PR [#144](https://github.com/EvoMap/evolver/pull/144)）。\n- [LKCY33](https://github.com/LKCY33) -- .env 読み込みパスとディレクトリ権限を修正（PR [#21](https://github.com/EvoMap/evolver/pull/21)）。\n- [hendrixAIDev](https://github.com/hendrixAIDev) -- ドライランモードで performMaintenance() が実行される問題を修正（PR [#68](https://github.com/EvoMap/evolver/pull/68)）。\n- [toller892](https://github.com/toller892) -- events.jsonl forbidden_paths バグを独立に特定して報告（PR [#149](https://github.com/EvoMap/evolver/pull/149)）。\n- [WeZZard](https://github.com/WeZZard) -- SKILL.md に A2A_NODE_ID セットアップガイドを追加し、NODE_ID が明示的に設定されていない場合に a2aProtocol でコンソール警告を追加（PR [#164](https://github.com/EvoMap/evolver/pull/164)）。\n- [Golden-Koi](https://github.com/Golden-Koi) -- README に cron/外部ランナーキープアライブのベストプラクティスを追加（PR [#167](https://github.com/EvoMap/evolver/pull/167)）。\n- [upbit](https://github.com/upbit) -- evolver および evomap 技術の普及に重要な役割を果たした。\n- [Chi Jianqiang](https://mowen.cn) -- プロモーションとユーザー体験の改善に多大な貢献。\n\n## ライセンス\n\n[GPL-3.0-or-later](https://opensource.org/licenses/GPL-3.0)\n\n\u003e コア進化エンジンモジュールは、知的財産を保護するために難読化された形式で配布されます。ソース: [EvoMap/evolver](https://github.com/EvoMap/evolver)。\n","funding_links":[],"categories":["AI Agent Frameworks \u0026 SDKs","JavaScript","Repos"],"sub_categories":["Multi-Agent Collaboration Systems"],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2FEvoMap%2Fevolver","html_url":"https://awesome.ecosyste.ms/projects/github.com%2FEvoMap%2Fevolver","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2FEvoMap%2Fevolver/lists"}