2023-09-05 04:11:34 +03:00
# Communicative Agents for Software Development
2023-09-04 19:15:33 +03:00
< p align = "center" >
< img src = './misc/logo1.png' width = 600 >
< / p >
< p align = "center" >
2023-10-08 07:32:35 +03:00
【< a href = "README.md" > English< / a > | < a href = "README-Chinese.md" > Chinese< / a > | Japanese | < a href = "README-Korean.md" > Korean< / a > | < a href = "README-Filipino.md" > Filipino< / a > | < a href = "README-French.md" > French< / a > 】
2023-09-04 19:15:33 +03:00
< / p >
2023-09-25 06:30:59 +03:00
< p align = "center" >
【📚 < a href = "wiki.md" > Wiki< / a > | 🚀 < a href = "wiki.md#local-demo" > ローカルデモ< / a > | 👥 < a href = "Contribution.md" > コミュニティにより作られたソフト< / a > | 🔧 < a href = "wiki.md#customization" > カスタマイズ< / a > 】
< / p >
2023-09-04 19:15:33 +03:00
## 📖 概要
2023-09-25 06:35:53 +03:00
- **ChatDev** は、最高経営責任者 < img src = 'online_log/static/figures/ceo.png' height = 20 > 、
2023-10-02 07:18:13 +03:00
最高製品責任者 < img src = 'online_log/static/figures/cpo.png' height = 20 > 、最高技術責任者 < img src = 'online_log/static/figures/cto.png' height = 20 > 、プログラマー < img src = 'online_log/static/figures/programmer.png' height = 20 > 、レビュアー < img src = 'online_log/static/figures/reviewer.png' height = 20 > 、テスター < img src = 'online_log/static/figures/tester.png' height = 20 > 、アートデザイナー < img src = 'online_log/static/figures/designer.png' height = 20 > などさまざまな役割を持つさまざまな**インテリジェントエージェント**を擁する**バーチャルソフトウェア企業**である。これらのエージェントはマルチエージェントの組織構造を形成し、
2023-09-25 06:30:59 +03:00
"プログラミングを通じてデジタル世界に革命を起こす"というミッションで
2023-09-25 06:35:53 +03:00
結束しています。ChatDev 内のエージェントは、設計、コーディング、テスト、ドキュメント作成などのタスクを含む専門的な機能セミナーに参加することで、
2023-09-25 06:30:59 +03:00
**共同作業** を行います。
- ChatDev の主な目的は、**使いやす**く**高度にカスタマイズ可能**で**拡張可能**なフレームワークを提供することであり、
これは大規模言語モデル( LLM) に基づいており、集合知を研究するための理想的なシナリオとして機能します。
2023-10-02 07:18:13 +03:00
< p align = "center" >
< img src = './misc/company.png' width = 600 >
< / p >
2023-09-04 19:15:33 +03:00
## 📰 ニュース
2023-10-02 07:18:13 +03:00
* **2023年9月25日: **Git** 機能が利用可能になりました**、プログラマー < img src = 'online_log/static/figures/programmer.png' height = 20 > がバージョン管理に GitHub を利用できるようになります。この機能を有効にするには、``ChatChainConfig.json`` で ``"git_management"`` を ``"True"`` に設定するだけです。
< p align = "center" >
< img src = './misc/github.png' width = 600 >
< / p >
* 2023年9月20日: **Human-Agent-Interaction** モードが利用可能になりました!レビュアー < img src = 'online_log/static/figures/reviewer.png' height = 20 > になってプログラマー < img src = 'online_log/static/figures/programmer.png' height = 20 > に提案することで、ChatDev チームに参加することができます;
``python3 run.py --task [description_of_your_idea] --config "Human"`` を試してみてください。また、[ガイド](wiki.md#human-agent-interaction)と[例](WareHouse/Gomoku_HumanAgentInteraction_20230920135038)を参照してください。
< p align = "center" >
< img src = './misc/Human_intro.png' width = 600 >
< / p >
* 2023年9月1日: **Art** モードが利用可能になりました!デザイナーエージェント < img src = 'online_log/static/figures/designer.png' height = 20 > を有効にすると、ソフトウェアで使用する画像を生成できます;
``python3 run.py --task [description_of_your_idea] --config "Art"`` を試してみてください。また、[ガイド](wiki.md#art)と[例](WareHouse/gomokugameArtExample_THUNLP_20230831122822)を参照してください。
2023-09-10 09:45:40 +03:00
* 2023年8月28日: システムが一般公開されました。
2023-10-02 07:18:13 +03:00
* 2023年8月17日: v1.0.0 のリリース準備が整いました。
2023-09-04 19:15:33 +03:00
* 2023年7月30日: ユーザーは、ChatChain、Phase、Role の設定をカスタマイズすることができます。さらに、オンラインログモードとリプレイモードの両方がサポートされました。
2023-09-10 09:45:40 +03:00
* 2023年7月16日: このプロジェクトに関連した[プレプリント論文](https://arxiv.org/abs/2307.07924)が発表されました。
2023-10-02 07:18:13 +03:00
* 2023年6月30日: ChatDev リポジトリの初期バージョンがリリースされました。
2023-09-04 19:15:33 +03:00
## ❓ ChatDev は何ができるのか?
![intro ](misc/intro.png )
https://github.com/OpenBMB/ChatDev/assets/11889052/80d01d2f-677b-4399-ad8b-f7af9bb62b72
## ⚡️ クイックスタート
開始するには、以下の手順に従ってください:
1. **GitHub リポジトリのクローン:** コマンドを使ってリポジトリのクローンを作成する:
```
git clone https://github.com/OpenBMB/ChatDev.git
```
2023-09-06 06:06:31 +03:00
2. **Python 環境のセットアップ:** バージョン 3.9 以上の Python 環境があることを確認してください。`ChatDev_conda_env`
をお好みの環境名に置き換え、以下のコマンドを使用してこの環境を作成し、有効化することができます:
2023-09-04 19:15:33 +03:00
```
conda create -n ChatDev_conda_env python=3.9 -y
conda activate ChatDev_conda_env
```
3. **依存関係のインストール:** `ChatDev` ディレクトリに移動し、以下のコマンドを実行して必要な依存関係をインストールする:
```
cd ChatDev
pip3 install -r requirements.txt
```
2023-09-06 06:06:31 +03:00
4. **OpenAI API キーの設定:** OpenAI API key を環境変数としてエクスポートします。`"your_OpenAI_API_key"` を実際の API
キーに置き換えてください。この環境変数はセッション固有なので、新しいターミナルセッションを開くときに再度設定する必要があることを覚えておいてください。
2023-09-04 19:15:33 +03:00
Unix/Linux 上では:
```
export OPENAI_API_KEY="your_OpenAI_API_key"
```
Windows 上では:
```
$env:OPENAI_API_KEY="your_OpenAI_API_key"
```
2023-09-06 06:06:31 +03:00
5. **ソフトウェアの構築:** 次のコマンドを使用して、ソフトウェアのビルドを開始する。`[description_of_your_idea]`
をあなたのアイデアの説明に、`[project_name]` を希望するプロジェクト名に置き換える:
2023-09-12 06:11:20 +03:00
Unix/Linux 上では:
2023-09-04 19:15:33 +03:00
```
python3 run.py --task "[description_of_your_idea]" --name "[project_name]"
```
2023-09-12 06:11:20 +03:00
Windows 上では:
```
python run.py --task "[description_of_your_idea]" --name "[project_name]"
```
2023-09-06 06:06:31 +03:00
6. **ソフトウェアの実行:** 生成されたソフトウェアは、`Project_name_DefaultOrganization_timestamp`
のような特定のプロジェクトフォルダの下の `WareHouse`
ディレクトリにあります。そのディレクトリで以下のコマンドを使ってソフトウェアを実行してください:
2023-09-12 06:11:20 +03:00
Unix/Linux 上では:
2023-09-04 19:15:33 +03:00
```
cd WareHouse/project_name_DefaultOrganization_timestamp
python3 main.py
```
2023-09-12 06:11:20 +03:00
Windows 上では:
```
cd WareHouse/project_name_DefaultOrganization_timestamp
python main.py
```
2023-09-25 06:30:59 +03:00
2023-09-04 19:15:33 +03:00
## ✨️ 高度なスキル
より詳細な情報については、私たちの [Wiki ](wiki.md ) を参照してください:
2023-09-25 06:30:59 +03:00
- すべてのコマンド実行パラメータの紹介。
2023-09-04 19:15:33 +03:00
- 強化されたビジュアライズされたログ、リプレイデモ、シンプルな ChatChain ビジュアライザを含む、ローカルウェブデモをセットアップするための簡単なガイド。
- ChatDev フレームワークの概要
- ChatChain 設定の高度なパラメータの包括的な紹介。
- ChatDev をカスタマイズするためのガイドです:
2023-09-06 06:06:31 +03:00
- ChatChain:
独自のソフトウェア開発プロセス(または他のプロセス)を設計します。例えば ``DemandAnalysis -> Coding -> Testing -> Manual``
などです。
2023-09-04 19:15:33 +03:00
- Phase: ``DemandAnalysis``のように、ChatChain 内で独自のフェーズを設計する。
- Role: 最高経営責任者 ``Chief Executive Officer`` のように、社内の様々なエージェントを定義する。
2023-09-25 06:35:53 +03:00
## 🤗 ソフトウェアをシェア!
2023-09-04 19:15:33 +03:00
2023-09-06 06:06:31 +03:00
**コード**:
私たちは、あなたが私たちのオープンソースプロジェクトに参加してくださることに熱意をもっています。もし何か問題があれば、遠慮なく報告してください。問い合わせがある場合、または私たちと仕事を共有する用意がある場合は、遠慮なくプルリクエストを作成してください!あなたのコントリビュートは高く評価されます。また、何かありましたらお知らせください!
**カンパニー**: カスタマイズした "ChatDev Company"
の作成は簡単です。このパーソナライズされたセットアップには、3つの簡単な設定JSONファイルが必要です。``CompanyConfig/Default``
ディレクトリで提供されている例をチェックしてください。カスタマイズの詳細については [Wiki ](wiki.md ) を参照してください。
2023-09-04 19:15:33 +03:00
2023-09-06 06:06:31 +03:00
**ソフトウェア**: ChatDev
を使ってソフトウェアを開発すると、必要な情報を含むフォルダが作成されます。プルリクエストを行うだけで、あなたの作品を共有することができます。コマンド ``python3 run.py --task "design a 2048 game" --name "2048" --org "THUNLP" --config "Default"``
を実行してください。これでソフトウェアパッケージが作成され、``/WareHouse/2048_THUNLP_timestamp``
という名前のフォルダが生成されます。内部には:
2023-09-04 19:15:33 +03:00
- 2048 ゲームソフトウェアに関連するすべてのファイルとドキュメント
- ``CompanyConfig/Default`` にある 3 つの JSON 設定ファイルを含む、このソフトウェアを開発した会社の設定ファイル
- リプレイに使用できる、このソフトウェアのビルドプロセスの詳細なログ(``timestamp.log``)
- このソフトウェアを作成するために使用された最初のプロンプト (``2048.prompt``)
2023-09-10 09:45:40 +03:00
**コミュニティによって投稿されたソフトウェアは[こちら](Contribution.md)を参照してください!**
2023-09-04 19:15:33 +03:00
2023-09-06 06:06:31 +03:00
### ソフトウェア共有者
< a href = "https://github.com/qianc62" > < img src = "https://avatars.githubusercontent.com/u/48988402?v=4" alt = "Contributor" style = "width:5%; border-radius: 50%;" / > < / a >
< a href = "https://github.com/thinkwee" > < img src = "https://avatars.githubusercontent.com/u/11889052?v=4" alt = "Contributor" style = "width:5%; border-radius: 50%;" / > < / a >
< a href = "https://github.com/NA-Wen" > < img src = "https://avatars.githubusercontent.com/u/92134380?v=4" alt = "Contributor" style = "width:5%; border-radius: 50%;" / > < / a >
< a href = "https://github.com/lijiahao2022" > < img src = "https://avatars.githubusercontent.com/u/111221887?v=4" alt = "Contributor" style = "width:5%; border-radius: 50%;" / > < / a >
2023-10-09 08:59:45 +03:00
< a href = "https://github.com/Alphamasterliu" > < img src = "https://avatars.githubusercontent.com/u/110011045?v=4" alt = "Contributor" style = "width:5%; border-radius: 50%;" / > < / a >
2023-09-06 06:06:31 +03:00
< a href = "https://github.com/GeekyWizKid" > < img src = "https://avatars.githubusercontent.com/u/133981481?v=4" alt = "Contributor" style = "width:5%; border-radius: 50%;" / > < / a >
2023-09-25 06:30:59 +03:00
< a href = "https://github.com/Munsif-Raza-T" > < img src = "https://avatars.githubusercontent.com/u/76085202?v=4" alt = "Contributor" style = "width:5%; border-radius: 50%;" / > < / a >
2023-10-09 08:59:45 +03:00
< a href = "https://github.com/djbritt" > < img src = "https://avatars.githubusercontent.com/u/28036018?v=4" alt = "Contributor" style = "width:5%; border-radius: 50%;" / > < / a >
< a href = "https://github.com/Classified3939" > < img src = "https://avatars.githubusercontent.com/u/102702965?v=4" alt = "Contributor" style = "width:5%; border-radius: 50%;" / > < / a >
< a href = "https://github.com/chenilim" > < img src = "https://avatars.githubusercontent.com/u/46905241?v=4" alt = "Contributor" style = "width:5%; border-radius: 50%;" / > < / a >
< a href = "https://github.com/delconis" > < img src = "https://avatars.githubusercontent.com/u/5824478?v=4" alt = "Contributor" style = "width:5%; border-radius: 50%;" / > < / a >
< a href = "https://github.com/eMcQuill" > < img src = "https://avatars.githubusercontent.com/u/139025701?v=4" alt = "Contributor" style = "width:5%; border-radius: 50%;" / > < / a >
2023-09-04 19:15:33 +03:00
## 📑 引用
```
@misc {qian2023communicative,
title={Communicative Agents for Software Development},
author={Chen Qian and Xin Cong and Wei Liu and Cheng Yang and Weize Chen and Yusheng Su and Yufan Dang and Jiahao Li and Juyuan Xu and Dahai Li and Zhiyuan Liu and Maosong Sun},
year={2023},
eprint={2307.07924},
archivePrefix={arXiv},
primaryClass={cs.SE}
}
```
## ⚖️ ライセンス
2023-10-02 07:18:13 +03:00
- ソースコードのライセンス 私たちのプロジェクトのソースコードは、Apache 2.0 License の下でライセンスされています。このライセンスは、Apache 2.0 ライセンスに概説されている特定の条件に従い、コードの使用、変更、配布を許可します。
- プロジェクトのオープンソース化状況: このプロジェクトは確かにオープンソースです; が、この指定は主に非商業的な目的を意図しています。私たちは、研究や非商業的なアプリケーションのためのコミュニティからの協力や貢献を奨励しますが、商業的な目的でプロジェクトのコンポーネントを利用する場合は、個別のライセンス契約が必要であることに注意することが重要です。
- データライセンス: このプロジェクトで利用された関連データは、CC BY-NC 4.0 でライセンスされており、このライセンスは、データの非商用利用を明確に許可しています。これらのデータセットを用いて学習されたモデルは、非商用利用の制限を厳守し、研究目的のみに使用されるべきであることを強調しておきます。
2023-09-06 06:06:31 +03:00
## Star History
[![Star History Chart ](https://api.star-history.com/svg?repos=openbmb/chatdev&type=Date )](https://star-history.com/#openbmb/chatdev& Date)
2023-09-07 05:17:56 +03:00
## お問い合わせ
2023-09-10 09:45:40 +03:00
ご質問、フィードバック、またはお問い合わせがある場合は、[chatdev.openbmb@outlook.com](mailto:chatdev.openbmb@outlook.com) までお気軽にご連絡ください