はじめに
OpenChain Japan Work Group - FAQサブグループのリーダを担当しております。
好きなライセンスは The Beer-ware License🍺 です。
FAQサブグループの紹介は過去に2回ほど(1回目 / 2回目)やっていて正直ネタ切れなので、今回はLLMで遊んでみました。
オープンソースライセンスとLLM
というわけで、適当にLLMに
ソースコード開示が必要なライセンスと、開示不要なライセンスをそれぞれ30個ずつリストしてください。
という(意図的に)意地悪な質問を投げてみました。
結果は、こんなかんじ。
ご注意
以下のLLMの出力はいくつか明らかに間違っています。くれぐれもこの出力を信用しないでください。
CAUTION
Some of the LLM output below is obviously wrong. Do not trust this output.
了解しました!以下にソースコードの開示が必要なライセンスと不要なライセンスをそれぞれ30個ずつリストします。
ソースコード開示が必要なライセンス
- GPL (GNU General Public License)
- AGPL (GNU Affero General Public License)
- MPL (Mozilla Public License)
- EPL (Eclipse Public License)
- CPL (Common Public License)
- EUPL (European Union Public License)
- OSL (Open Software License)
- CECILL (CEA CNRS INRIA Logiciel Libre)
- SISSL (Sun Industry Standards Source License)
- GPLv2 (GNU General Public License version 2)
- GPLv3 (GNU General Public License version 3)
- LGPL (Lesser General Public License)
- GPL-2.0-only
- GPL-2.0-or-later
- GPL-3.0-only
- GPL-3.0-or-later
- AGPL-3.0-only
- AGPL-3.0-or-later
- EPL-1.0
- EPL-2.0
- CDDL (Common Development and Distribution License)
- IPL (IBM Public License)
- NPL (Netscape Public License)
- SPL (Sun Public License)
- RPL (Reciprocal Public License)
- APSL (Apple Public Source License)
- ECL (Educational Community License)
- MS-PL (Microsoft Public License)
- ZPL (Zope Public License)
- QPL (Q Public License)
ソースコード開示が不要なライセンス
- MIT License
- BSD 2-Clause License
- BSD 3-Clause License
- Apache License 2.0
- Unlicense
- ISC License
- Zlib License
- Boost Software License 1.0
- CC0 1.0 Universal (Creative Commons Zero)
- WTFPL (Do What The F*ck You Want To Public License)
- X11 License
- Python Software Foundation License
- PHP License
- Ruby License
- Perl Artistic License
- ECL (Educational Community License)
- NCSA License
- OpenSSL License
- PostgreSQL License
- SIL Open Font License
- MIT-0 License
- BSD-4-Clause License
- BSD-3-Clause-Clear License
- BSD-3-Clause-Attribution License
- BSD-3-Clause-LBNL License
- Apache License 1.1
- Apache License 1.0
- JSON License
- Libpng License
- Microsoft Reciprocal License (MS-RL)
これでリストが30個ずつになりました。何か他に知りたいことがあれば教えてくださいね!
はい。明らかに嘘(ハルシネーション)がいくつか出ていますね。続けてみましょう。
ご注意
こちらも結構怪しいですので鵜呑みされませんよう。
CAUTION
This is also quite suspicious, so don't take it with a grain of salt.
MS-PL (Microsoft Public License)の責務について教えて
Microsoft Public License (MS-PL) の主な責務について説明します。
MS-PLの主な責務
著作権、特許、商標、帰属通知の保持:
- ソフトウェアを配布する際には、元の著作権、特許、商標、および帰属通知を保持する必要があります。
ソースコードの配布:
- ソースコード形式でソフトウェアを配布する場合、MS-PLライセンスの完全なコピーを含める必要があります。
- コンパイル済みまたはオブジェクトコード形式で配布する場合、MS-PLと互換性のあるライセンスの下で配布する必要があります。
商標の使用制限:
- 貢献者の名前、ロゴ、または商標の使用権は付与されません。
責任の免除:
- ソフトウェアは「現状のまま」提供され、使用に伴うリスクは利用者が負います。明示的な保証はなく、適用される法律の範囲内で暗黙の保証も排除されます。
特許クレームの制限:
- ソフトウェアに対して特許クレームを提起した場合、その特許ライセンスは自動的に終了します。
MS-PLは、ソースコードの開示義務がない点で他のコピーレフトライセンスとは異なりますが、配布時の通知保持やライセンスの互換性に関する条件があるため、使用する際には詳細を確認することが重要です。
他に知りたいことがあれば教えてくださいね!
2. **ソースコードの配布:**
とか言っておきながら〆で MS-PLは、ソースコードの開示義務がない点で~
とも言っていて非常に誤解のある表現になっていますね。しかもあなたソースコード開示が必要なライセンスにリストしてたじゃないか…。
もうひとつ。
Microsoft Reciprocal License (MS-RL) の責務について教えて
Microsoft Reciprocal License (MS-RL) の主な責務について説明します。
MS-RLの主な責務
ソースコードの開示:
- MS-RLライセンスのコードを含むファイルを配布する場合、そのファイルのソースコードを受信者に提供し、このライセンスのコピーを含める必要があります。
同一ライセンスでの配布:
- MS-RLライセンスのコードを含むファイルは、同じMS-RLライセンスの下で配布する必要があります。
著作権および特許の通知保持:
- ソフトウェアの配布時には、元の著作権、特許、商標、および帰属通知を保持する必要があります。
特許クレームの制限:
- ソフトウェアに対して特許クレームを提起した場合、その特許ライセンスは自動的に終了します。
商標の使用制限:
- このライセンスは、貢献者の名前、ロゴ、または商標の使用権を付与しません。
「現状のまま」提供:
- ソフトウェアは「現状のまま」提供され、使用に伴うリスクは利用者が負います。明示的な保証はなく、適用される法律の範囲内で暗黙の保証も排除されます。
MS-RLは、ソースコードの開示と同一ライセンスでの配布を求める点で、他のコピーレフトライセンスと似ていますが、特定の条件や制限があるため、使用する際には詳細を確認することが重要です。
他に知りたいことがあれば教えてくださいね!
間違ってなさそうに見えるけどこれも最初の問いでソースコード開示が不要なライセンス
に分類してたね…。
まとめ
こんなに自信満々で言われるとついつい信じたくなってしまいますが、やはりまだLLMの出力はちゃんと検証する必要があります。この誤りは実際にライセンス文を読んでみないと気づけないので、きちんと自分で読んで理解することが重要です。
というわけで、LLMは便利だけど、ちょいちょいアレなところがあるので使い方には気を付けましょう!(自戒含む)
English Summary
When I asked LLM to list 30 licenses that require and do not require source code disclosure, several halcynics occurred. When I asked LLM to describe the responsibilities of one of them, it produced a misleading statement.
It turned out that LLM's output still needs to be verified and not swallowed.